【C++笔试强训】第五天

news2025/1/11 21:47:42

文章目录

    • 选择题
    • 编程题

选择题

在上下文和头文件均正常情况下,以下程序的输出结果是()

int x = 1;
do{
	printf("%2d\n",x++)
}while(x--);

A 1
B 无任何输出
C 2
D 陷入死循环

x=1,x++是后置++,先使用,在加加。x=2进入while条件判断,x–-等于1为真又继续进入循环,如此重复下去陷入死循环,选D

定义char dog[]=“wang\0miao”;那么sizeof(dog)与strlen(dog)分别是多少()
A 10,4
B 4,4
C 9,9
D 9,4

理解sizeof与strlen所代表含义:sizeof:求变量所对应类型占的字节数,strlen:求字符串的有效长度,不包括\0在内(遇到\0就返回)
"wang\0miao\0"最后还包含了一个\0,sizeof所占字节数是10;strlen所求长度是4

下列程序的打印结果是()

char p1[15] = "abcd", *p2 = "ABCD", str[50] = "xyz";
strcpy(str + 2, strcat(p1 + 2, p2 + 1));
printf("%s", str);

A xyabcAB
B abcABz
C ABabcz
D xycdBCD

理解strcpy和strcat所代表的含义即可解决此题:

strcpy(p,q):将q字符串中的内容拷贝到p所在的空间中,最后返回p(p的空间大小一定要能够存的下q中的字符总数,否则会崩溃)
strcat(p,q):将字符串中内内容拼接在p字符串之后,最终返回p(p空间要容纳得下q拼接的字符)也就是追加,在细心比对题目,选D

下面程序的输出结果是()

#include<iosteam.h>

void main(){
	int n[][3] = {10,20,30,40,50,60};
	int (*p)[3];
	p=n;
	cout<<p[0][0]<<","<<*(p[0]+1)<<","<<(*p)[2]<<endl;
}

A 10,30,50
B 10,20,30
C 20,40,60
D 10,30,60

n是2行3列的二维数组,p是一个数组指针,指向有具有3个int类型元素的一段连续空间,p[0][0] 是第一行第一个地址的值,即为n[0][0],也就是10;*(p[0]+1):等价于p[0][1] ,也就是20;(*p)[2]:p等价于(p+0),也就是p[0],所以(*p)[2]等价于p[0][2],也就是30

对于p[0]、*(p+0)、*p这三个都是等价的

以下说法中正确的是( )。
A C++程序中的main()函数必须放在程序的开始部分
B C++程序的入口函数是main函数
C 在C++程序中,要调用的函数必须在main()函数中

A选项是没有要求的;main函数是入口函数。对于C选项:在C++中,函数不能嵌套定义,所以C是错误的,选B

有以下程序运行结果为()

#include <iostream>
using namespace std;
char fun(char x, char y) {
	if (x < y)
		return x;
	return y;
}
int main() {
	int a = '1', b = '1', c = '2';
	cout << fun(fun(a, b), fun(b, c));
	return 0;
}

A 运行出错
B 2
C 3
D 1

代入比较即可选D

对于int* pa[5];的描述,以下哪个选项是正确的()
A pa是一个具有5个元素的指针数组,每个元素是一个int类型的指针;
B pa是一个指向数组的指针,所指向的数组是5个int类型的元素;
C pa[5]表示某个数的第5个元素的值;
D pa是一个指向某个数组中第5个元素的指针,该元素是int类型的变量

pa是一个指针数组,每个元素都是int*类型的指针,A是对的,选A

下面两个结构体
在#pragma pack(4)和#pragma pack(8)的情况下,结构体的大小分别是()

struct One{
	double d;
	char c;
	int i;
}
struct Two{
	char c;
	double d;
	int i;
}

A 16 24,16 24
B 16 20,16 20
C 16 16,16 24
D 16 16,24 24

还是结构体对齐内容,分别按照4字节和8字节的方式,这里就不展开了,对于结构体对齐还不清楚的童鞋,建议去看我之前的文章:选C

下面哪个指针表达式可以用来引用数组元素a[i][j][k][l]()

A (((a+i)+j)+k)+l)

B *(*(*(*(a+i)+j)+k)+l)

C (((a+i)+j)+k+l)

D ((a+i)+j+k+l)
我们简单举个例子:比如b[1][2] = *(b[1]+2) = *(*(b+1)+2),继续根据这样子下去,a[i][j][k][l],套娃下去,选B

由多个源文件组成的C程序,经过编辑、预处理、编译、链接等阶段会生成最终的可执行程序。下面哪个阶段可以发现被调用的函数未定义()
A 预处理
B 编译
C 链接
D 执行

理解各个阶段,对于编辑:写代码过程
预处理:宏替换、头文件展开、条件编译、去注释(头文件不参与编译)
编译:只对源文件进行编译,每个源文件编译完成都会生成obj的目标文件
汇编:将汇编指令翻译成对应的二进制格式
链接:链接目标文件合并形成一个可执行程序,还需解决地址问题
在链接的时候知道函数有没有被定义,选C


编程题

连续最大和

image-20221204200158914

动态规划:

状态方程式: max( dp[ i ] ) = getMax( max( dp[ i -1 ] ) + arr[ i ] ,arr[ i ] )

dp[i] 所代表的含义:就是以数组下标为 i 的数做为结尾的最大子序列和,分两种情况:dp[i-1] + arr[i] 大还是dp[i]大,通过GetMax函数选大的

image-20221204201443705

#include <iostream>
#include <vector>
using namespace std;

int GetMax(int a,int b)
{
    return a>b?a:b;
}
int main()
{
    int N;
    cin>>N;
    vector<int> v(N);
    for(size_t i = 0;i<v.size();i++)
    {
        cin>>v[i];
    }
    int sum = v[0];
    int max = v[0];
    for(size_t i = 1;i<v.size();i++)
    {
        sum=GetMax(sum+v[i],v[i]);
        if(sum>=max)
        {
            max = sum;
        }
    }
    cout<<max<<endl;
    return 0;
}

统计回文

image-20221204201554314

跟着题目的意思来即可,可以单独写一个函数来进行判断是否为回文。判断插入之后是否为回文串即可。

#include <iostream>
#include <string>
using namespace std;
bool IsCircle(string s)
{
    int begin = 0;
    int end = s.size()-1;
    while(begin<end) 
    {
        if(s[begin]!=s[end])
        {
            return false;
        }
        ++begin;
        --end;
    }
    return true;
}

int main() {
    string ret;
    string str;
    getline(cin,ret);
    getline(cin,str);
    int count = 0;
    for(size_t i = 0;i<=ret.size();i++)
    {
        string tmp = ret;
        tmp.insert(i,str);
        if(IsCircle(tmp))
        {
            ++count;
        }
    }
    cout<<count<<endl;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/82674.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python之路200个小例子网页版,真诚奉献,从一而终!

前言 历史两个月&#xff0c;利用所有业余时间&#xff0c;与朋友一起搜集、创作Python小例子&#xff0c;截止目前已超过200个例子&#xff1a; Python之路 1 简洁之美 2 Python绘图 3 Python动画 4 Python数据分析 5 Python机器学习 6 Python-GUI 一、Python基础 1…

Acrel-EIOT免调试抄表系统

安科瑞 华楠 一、远程抄表系统应用场景-互联网用户&#xff08;能源参与者&#xff09; 二、远程抄表系统互联网用户的痛点 2.1 数据系统价格偏高 一套系统需要前期勘察、画图、出方案、报价&#xff0c;建设投入服务器、网络布线、交换机&#xff0c;网关、人工施工及调试&…

Vue中使用vxe-table组件分页查询,多页选择数据回显,分页记录保存选中的数据

官方示例&#xff1a;vxe-table v3https://vxetable.cn/v3/#/table/advanced/page 当表格中需要渲染的数据量比较大&#xff0c;有几万几十万条数据时&#xff0c;在前端分页将会非常慢&#xff0c;建议将当前页码和每页数量传递个后端&#xff0c;后端分好后给前端渲染。 后端…

电脑重装小白系统没内存怎该如何解决

很多网友想要重装系统&#xff0c;但是在用小白系统安装的时候提示没内存怎么办呢?我们可以卸载自己的电脑软件&#xff0c;或者是扩充一下自己电脑内存。不知道如何处理相关问题的小伙伴可以直接看看下面小编分享的文章小白系统没内存怎么办。 工具/原料&#xff1a; 系统版…

MySQL主从复制-----读写分离

MySQL主从复制是一个异步的复制过程&#xff0c;底层是基于Mysql数据库自带的二进制日志功能。就是一台或多台Mysql数据库&#xff08;slave从库&#xff09;从另一台mysql数据库&#xff08;master,主库&#xff09;进行日志的复制然后再解析日志并应用到自身&#xff0c;最终…

nacos--基础--2.5--部署--集群--传统

nacos–基础–2.5–部署–集群–传统 前提 使用hd用户登陆 完成基础环境搭建https://blog.csdn.net/zhou920786312/article/details/1182123021、机器 IP端口备注192.168.187.1718848xx192.168.187.1728848xx192.168.187.1738848xx 2、tar.gz安装 2.1、安装 参考 nacos–基…

javaee之黑马旅游网4

下面来做旅游线路的查询功能 1.查询参数传递 在header.html 我们先找到这部分的位置 上面就加了两个id 引入这个js文件 控制搜索框 那我们现在来说一下&#xff0c;cid怎么来获取&#xff0c;换句话说cid是从什么地方传过来的&#xff1f; 首先header.html页面是被包含在r…

人力资源杂志人力资源杂志社人力资源编辑部2022年第20期目录

专题研究《人力资源》投稿&#xff1a;cnqikantg126.com 破解高端人才引聚难 林翠玲; 1-3 如何凸显集团企业人力资源管理价值 刘鹏飞; 4-5 中长期激励&#xff0c;激活科研人员创新力 刘灿;汪思源; 6-7 改革人才评价体系&#xff0c;助推“双一流”建设 杨帆; …

STM32CUBEMX_配置stm32f103c8t6的bootloader_USB升级

STM32CUBEMX_配置stm32f103c8t6的bootloader_USB升级 1、使用stm32cubemx配置好工程&#xff08;版本6.3.0&#xff09;&#xff0c;生成keil工程 2、移植必须要的一些函数 3、使用dfusedemo工具软件测试 ①配时钟外设 ②配ST-Link调试接口&#xff08;防止无法二次烧录程序&a…

理解Python的协程(Coroutine)

生成器(Generator) yield表达式的使用生产者和消费者模型yield from表达式协程(Coroutine) asyncio.coroutineasync/await总结参考链接 由于GIL的存在&#xff0c;导致Python多线程性能甚至比单线程更糟。 GIL: 全局解释器锁&#xff08;英语&#xff1a;Global Interpreter Lo…

InvocationException: GraphViz‘s executables not found【BUG已解决】

项目场景&#xff1a; 在机器学习框架中遇到了一个bug&#xff1a;安装了GraphViz模块后&#xff0c;在对着sklearn的决策树文档操作输出决策树模型结果时&#xff0c;还是爆出了如下的错误&#xff1a; 报错位置为&#xff1a; display(Image(graph.create_png())) graph.wr…

艾美捷低内毒素CpG ODN寡聚脱氧核苷酸全家族系列

免疫佐剂&#xff0c;是一类可以增强抗原免疫原性的免疫调节分子、化合物或大分子复合物。大多数佐剂可以通过启动先天免疫系统来辅助抗原应答。先天免疫系统通过模式识别受体&#xff08;pattern recognition receptor&#xff0c;PRR&#xff09;来感知各种微生物表达的病原体…

SQL通用语法及分类

目录 MySQL的启动和连接&数据模型 SQL通用语法及分类 Data Definition Language DDL - 数据库操作 DDL - 表操作 表操作 - 创建&&查询 表操作 - 数据类型 表操作-修改&&删除 DDL总结 Data Manipulation Language DML - 插入数据insert DML - 更…

高佣金流量卡上线

01 流量卡业务 常规的运营商套餐相对都比较贵&#xff0c;少则六七十一个月&#xff0c;多则几百块一个月&#xff0c;这样的套餐让运营商赚盆满钵满。 随着5G需求越来越多&#xff0c;其他第三方运营商也开始市场化营销&#xff0c;流量卡的CPA基本在60-200之间一张卡&…

汽车喷漆车间风淋室八大参数TENAISU

汽车喷漆车间风淋室风淋室配置八大参数 汽车喷漆车间风淋室及汽车涂装车间风淋室配置八大参数,光电感应自动功能系统、自动身份识别功能系统、自动臭氧杀菌功能系统、自动紫外线杀菌功能系统、自动除静电离子发生功能系统、可调延时开门功能系统、过滤器失效预警功能系统、自动…

焦脱镁叶绿酸-a修饰无机纳米材料/活性基团/上转换纳米发光颗粒/点击化学/抗体的应用

小编今天分享的科研知识是焦脱镁叶绿酸-a修饰无机纳米材料/活性基团/上转换纳米发光颗粒/点击化学/抗体的应用&#xff0c;一起来看&#xff01; 焦脱镁叶绿酸-a衍生物的应用&#xff1a; 叶绿素降解产物是合成光动力治疗药物的理想合成前体.为了获得新型叶绿素类光敏剂,以焦脱…

Vscode踩坑日记--行尾序列LF和CRLF

Vscode踩坑日记–行尾序列LF和CRLF 今天一上午什么也没干&#xff0c;一直配置Vscode&#xff0c;之前因为代码提交问题&#xff0c;需要解决配置一下eslint&#xff0c;问题就来了。 插件&#xff0c;配置信息什么都写好了还是一堆错误&#xff1f;&#xff1f;让我很懵逼 …

基于Java Springboot-MySQL实现学生信息成绩管理系统

学生成绩管理系统 项目设计的意义。 该系统的具体任务就是设计一个学生成绩的数据库管理系统&#xff0c;由计算机代替人工执行一系列诸如增加新学生成绩信息、删除学生成绩信息、学生资料、查询、修改等的处理操作&#xff0c;以方便管理人员的管理信息工作。本设计以学生成绩…

32种EMC标准电路 (共用)

01 AC24V接口EMC设计标准电路 02 AC110V-220VEMC设计标准电路 03 AC380V接口EMC设计标准电路 04 AV接口EMC设计标准电路 05 CAN接口EMC设计标准电路 06 DC12V接口EMC设计标准电路 07 DC24V接口EMC设计标准电路 08 DC48接口EMC设计标准电路 09 DC110V接口…

[附源码]Python计算机毕业设计SSM基于大数据的高校国有固定资产管理及绩效自动评价系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…