PTA—C语言期末复习(选择题)
1. 按照标识符的要求,(A)不能组成标识符。
A.连接符
B.下划线
C.大小写字母
D.数字字符
在大多数编程语言中,标识符通常由字母(包括大写和小写)、数字和下划线组成,但不能以数字开头,并且不能包含连接符等特殊字符。
2. 在C语言中,数字029是一个(D)。
A.八进制数
B.十进制数
C.十六进制数
D.非法数
八进制数以数字
0开头,但八进制数的数字只能是0 - 7。十进制数就是我们平常使用的普通数字,不需要前缀。
十六进制数以
0x或0X开头。例如,八进制数
027是合法的,十进制数29直接写为29,十六进制数0x1D是合法的。所以029是一个非法数
3. 若有char w; int x; float y; double z; 则表达式w*x+z-y值的数据类型为(D)。
A.float
B.char
C.int
D.double
在 C 语言中,当进行混合运算时,运算结果的类型会自动转换为参与运算的操作数中精度最高的类型.
4. 在c语言中,不允许有常量的数据类型是(B)
A.整型
B.结构型
C.字符型
D.字符串
结构体是一种自定义的数据类型,通常用于组合不同类型的数据来创建更复杂的数据结构,但结构体本身不能直接作为常量。结构体的变量可以有常量的值,但结构体类型不能直接表示为常量。
5. 下列运算符中优先级最低的是 (A)
A. II
B. >=
C. !=
D. ~
在 C 语言中,逻辑或运算符“||”的优先级低于关系运算符“>=”和“!=”,按位取反运算符“~”是单目运算符,优先级较高。关系运算符“>=”和“!=”的优先级相同。
例如,对于表达式
a >= b || c!= d,会先计算关系运算a >= b和c!= d,然后再进行逻辑或运算。
6. 若x为浮点型,则表达式x=10/4为(B)。
A. 2.5
B. 2.0
C. 2
D. 3
在 C 语言中,当整数相除(
10/4)时,结果会进行整数除法,得到的结果是整数2。之后将这个整数
2赋值给浮点型变量x时,会进行类型转换,将整数2转换为浮点数2.0。例如,如果后续对x进行输出,使用printf("%f", x);输出的结果将是2.000000。
7. 逻辑运算符两侧运算对象的数据类型(D)。
A. 只能是 0 或 1
B. 只能是 0 或非 0 正数
C. 只能是整型或字符型的数据
D. 可以是任何类型的数据
逻辑运算符包括
&&(逻辑与)、||(逻辑或)和!(逻辑非)对于逻辑与
&&和逻辑或||,其操作数会被隐式转换为布尔值(非零值被视为true,零值被视为false)进行运算.所以逻辑运算符两侧运算对象的数据类型可以是任意类型.
8. 若p1、p2都是整型指针,p1已经指向变量x,要使p2也指向x, (A)是正确的。 (重点)
A. p2 = p1;
B. p2 = **p1;
C. p2 = &p1;
D. p2 = *p1;
在 C 语言中,指针变量存储的是另一个变量的地址。
当
p1已经指向变量x时,要使p2也指向x,只需要将p1所存储的地址赋值给p2即可。选项 C 中,
&p1是取p1这个指针变量本身的地址,而不是x的地址。选项 D 中,
*p1是获取p1所指向变量的值,不是地址。例如,如果有
int x = 5; int *p1 = &x;,执行p2 = p1;后,对*p2的操作就等同于对*p1和x的操作。
9. 以下选项中,对基本类型相同的指针变量不能进行运算的运算符是(A)。
A. +
B. -
C. =
D. ==
在 C 语言中,对于基本类型相同的指针变量,可以进行减法运算(
-),用于计算两个指针之间的元素个数差。可以进行赋值运算(
=),将一个指针的值赋给另一个指针。可以进行比较运算(
==),判断两个指针是否指向相同的地址。但是不能进行加法运算(
+),因为指针的加法运算在 C 语言中没有明确的语义和定义。
10. int a=5,*ap=&a ;则下列表达式错误的是(D) (重点)
A. &*ap 相当于&a
B. *&a 相当于ap
C. (*ap)++ 相当于a++
D. *ap++ 是合法访问
选项 A 中,
&*ap,先进行*ap得到a,再对其取地址就是&a,所以该表达式正确。选项 B 中,
*&a,先对a取地址得到&a,再进行解引用就是a,与ap所指向的内容相同,所以该表达式正确。选项 C 中,
(*ap)++,先解引用得到a,然后对a进行自增,相当于a++,所以该表达式正确。选项 D 中,
*ap++是错误的,它的本意可能是先使用*ap的值,然后让ap指针自增。但由于运算符优先级的问题,这个表达式会先计算ap++,即让指针ap自增,然后再进行解引用,这不是预期的操作,所以该表达式错误。例如,如果按照错误的方式使用
*ap++,可能会导致程序出现未定义的行为或错误的结果
11. 下面是对s的初始化,其中不正确的是(D)
A. char s[5]={"abc"};
B. char s[5]={'a', 'b', 'c'};
C. char s[5]="";
D. char s[5]="abcdef";
选项 A ,
char s[5] = {"abc"};,数组长度为 5,初始化字符串"abc",剩余两个位置自动补'\0',是正确的。选项 B ,
char s[5] = {'a', 'b', 'c'};,这种初始化方式没有自动添加字符串结束符'\0',但在数组长度范围内,也是可以的。选项 C ,
char s[5] = "";,初始化一个空字符串,剩余位置自动补'\0',是正确的。选项 D ,
char s[5] = "abcdef";,初始化的字符串长度超过了数组的定义长度,会导致越界,是不正确的。例如,如果定义
char s[7] = "abcdef";,就是正确的初始化。
12. 若有int x=1;,执行下列程序段后,变量x的正确结果是:(D)

A. 1
B. 2
C. 3
D. 4
在这个
switch语句中,x * 10的值为10。首先会匹配到
case 10,执行x += 1,此时x的值变为2。由于没有break语句,会继续执行下面的case 11和default中的语句,分别再次执行x += 1。所以经过这一系列操作后,x的值最终变为4
13. 下列程序段的功能是(D)

A. 自然数1~9的累加和
B. 自然数1~10的累加和
C. 自然数1~9中的奇数之和
D. 自然数1~10中的偶数之和
在这个程序中,
for循环的条件是i < 10,且i的步长为2,即i依次取值为1、3、5、7、9。在循环体中,进行累加的是
i + 1,即2、4、6、8、10。所以这个程序段的功能是计算自然数
1到10中的偶数之和。例如,如果将循环体修改为
s += i,那么就是计算自然数1到9中的奇数之和。
14. 对于 C/C++语言的函数,下列叙述中正确的是(A)。
A. 函数的定义不能嵌套,但函数调用可以嵌套
B. 函数的定义可以嵌套,但函数调用不能嵌套
C. 函数的定义和调用都不能嵌套
D. 函数的定义和调用都可以嵌套
在 C/C++语言中,函数的定义不能嵌套,也就是说不能在一个函数的定义内部再定义另一个函数。但是函数的调用是可以嵌套的,即在一个函数内部可以调用其他函数,被调用的函数内部还可以再调用其他函数。
15. 在一个被调用函数中,关于 return 语句使用的描述,错误的是(D)。
A. 被调用函数中可以不用 return 语句
B. 被调用函数中可以使用多个 return 语句
C. 被调用函数中,如果有返回值,就一定要有 return 语句
D. 被调用函数中,一个 return 语句可以返回多个值给调用函数
选项 A ,被调用函数中可以不用
return语句,例如当函数不需要返回值时。选项 B ,被调用函数中可以使用多个
return语句,根据不同的条件在不同的位置返回。选项 C ,被调用函数中,如果有返回值,就一定要有
return语句来返回具体的值。选项 D ,一个
return语句只能返回一个值给调用函数,不能返回多个值。例如,一个计算两个数之和的函数,如果要返回结果,就需要使用
return a + b;这样的语句来返回一个值。
16. 若程序中定义了以下函数
double myadd(double a,double b)
{ return (a+b); }
并将其放在调用语句之后,则在调用之前应该对该函数进行说明, 以下选项中错误的说明是(A)。
A. double myadd(double a,b) ;
B. double myadd(double,double);
C. double myadd(double b,double a);
D. double myadd(double x,double y);
在函数声明中,每个参数都必须明确指定其类型,不能像选项 A 中那样只指定第一个参数的类型而省略第二个参数的类型。
选项 B 、C 、D 都是正确的函数声明方式,只要参数的类型正确,参数的名称可以与定义中的不同。
例如,如果函数调用时传递的参数类型与声明不一致,可能会导致编译错误。
17. 若有函数max(a,b),为了让函数指针变量p指向函数max,正确的赋值方式是(A)。
A. p=max;
B. *p=max;
C. p=max(a,b);
D. *p=max(a,b);
在 C 语言中,要让函数指针变量
p指向函数max,应该使用p = max;这种赋值方式。选项 B 中,
*p = max;这种写法是错误的,不能通过解引用的方式给函数指针赋值。选项 C 中,
p = max(a,b);这是调用函数max并将返回值赋给p,而不是让p指向函数max。选项 D 中,
*p = max(a,b);同样是错误的写法,不能对函数指针进行这样的操作。例如,如果后续通过
p来调用函数max,可以写成(*p)(a, b);
18. 若有函数int func(int a,int b),函数指针变量p已经指向func函数,那么下列用指针方式调用函数的正确方法是(C)。
A. (*p)func(2,3);
B. *func(2,3);
C. p(2,3);
D. *p(2,3);
当函数指针变量
p已经指向函数int func(int a, int b)时,用指针方式调用函数的正确方法是p(2, 3)。选项 A 中,
(*p)func(2, 3)这种写法是错误的,不能在函数指针前再加*然后跟函数名。选项 B 中,
*func(2, 3)这种写法是错误的,不能直接对函数名使用解引用操作。选项 D 中,
*p(2, 3)这种写法也是错误的。
19. 若有以下定义和语句:
int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a;
则不能表示a数组元素的表达式是(B)
A. *p
B. a[10]
C. *a
D. a[p-a]
选项 A ,
*p,因为p指向数组a的首元素,所以*p能表示数组a的第一个元素。选项 B ,
a[10],数组a的有效下标是0到9,a[10]超出了数组的范围,是错误的表达式。选项 C ,
*a,等同于a[0],能表示数组a的第一个元素。选项 D ,
a[p - a],因为p指向a的首元素,所以p - a的值为0,a[p - a]就等同于a[0],能表示数组a的第一个元素。
20. 若已定义:
int a[9],*p=a;
并在以后的语句中未改变p的值,不能表示a[1] 地址的表达式是(C)
A. p+1
B. a+1
C. a++
D. ++p
选项 A ,
p + 1,因为p是指向int类型的指针,p + 1表示指向数组a中下一个元素(即a[1])的地址。选项 B ,
a + 1,数组名a本身代表数组的首地址,a + 1表示数组中第二个元素(即a[1])的地址。选项 C ,数组名
a是一个地址常量,不能进行自增(a++)操作,这样的表达式是错误的。选项 D ,
++p,使p指向下一个元素(即a[1])的地址。例如,如果要通过指针访问
a[1]的值,可以使用*(p + 1)或者*(a + 1)。
21. 以下数组定义中错误的是(B)。
A. int x[][3]={0};
B. int x[2][3]={{1,2},{3,4},{5,6)};
C. int x[][3]={{1,2,3},(4,5,6)};
D. int x[2][3]={1,2,3,4,5,6};
对于二维数组
int x[2][3],初始化时应该提供两行数据,每行包含三个元素。选项 A ,
int x[][3]={0};,可以这样初始化,未明确指定行数,根据后面的初始化值可以推断出行数。选项 C ,
int x[][3]={{1, 2, 3}, {4, 5, 6}};,初始化方式正确。选项 D ,
int x[2][3]={1, 2, 3, 4, 5, 6};,按顺序初始化数组元素,方式正确。
22. 有两个字符数组a,b,则以下正确的输入语句是(B)
A. gets(a,b);
B. scanf("%s%s",a,b);
C. scanf("%s%s",&a,&b);
D. gets("a"),gets("b");
选项 A ,
gets函数一次只能接受一个字符串的输入,不能同时输入两个字符串,所以gets(a, b)是错误的。选项 B ,
scanf("%s%s", a, b)是正确的输入格式,可以依次输入两个字符串分别存储到数组a和b中。选项 C ,数组名本身就代表数组的首地址,不需要再使用取地址符
&,所以scanf("%s%s", &a, &b)是错误的。选项 D ,
gets函数的参数应该是字符数组名,而不是字符串"a"和"b",所以gets("a"), gets("b")是错误的。例如,如果输入
hello world,那么a中存储hello,b中存储world。
23. 下面的程序段将输出 (C) 。
char s[10] = "abcd";
printf("%d\n", sizeof(s));
A. 4
B. 5
C. 10
D. 11
sizeof操作符用于获取变量或数据类型所占的字节数。对于数组,sizeof返回的是数组分配的总字节数。
24. 设有数组定义:char array [ ]="China"; 则数组 array所占的空间为(C)。
A. 4个字节
B. 5个字节
C. 6个字节
D. 7个字节
字符串
"China"包含 5 个字符'C'、'h'、'i'、'n'、'a',但在 C 语言中,字符串会以'\0'作为结束标志。所以数组
array实际存储的是"China\0",共 6 个字符。每个字符占用 1 个字节,所以数组
array所占的空间为 6 个字节。例如,如果定义
char array[] = "Hello",那么数组实际存储的是"Hello\0",占用 6 个字节。
25. 对于以下定义,不正确的叙述是(B)。
struct ex { int x;float y;char z ;
} example;
A. struct是定义结构类型的关键字
B. example是结构类型名
C. x, y, z都是结构成员名
D. struct ex是结构类型名
struct ex是结构类型名,example是使用struct ex定义的结构变量名,而不是结构类型名。
海漫浩浩,我亦苦作舟!大家一起学习,一起进步!

相关文章:
PTA—C语言期末复习(选择题)
1. 按照标识符的要求,(A)不能组成标识符。 A.连接符 B.下划线 C.大小写字母 D.数字字符 在大多数编程语言中,标识符通常由字母(包括大写和小写)、数字和下划线组成,但不能以数字开头,…...
基于STM32的智能家用空气净化系统
目录 引言环境准备智能家用空气净化系统基础代码实现:实现智能家用空气净化系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统实现4.4 用户界面与数据可视化应用场景:空气净化管理与优化问题解决方案与优化收尾与总结 1. 引言 智能家用空气净化系…...
计算机图形学入门18:阴影映射
1.前言 前面几篇关于光栅化的文章中介绍了如何计算物体表面的光照,但是着色并不会进行阴影的计算,阴影需要单独进行处理,目前最常用的阴影计算技术之一就是Shadow Mapping技术,也就是俗称的阴影映射技术。 2.阴影映射 Shadow Map…...
电机应用相关名词介绍
1.电机转速 定义:电机转速指电机工作时旋转的速度,是衡量电机性能的重要指标之一。 单位: 每分钟转数(RPM):即Revolutions Per Minute,表示电机每分钟旋转的圈数。 每秒转数(RPS…...
哈尔滨等保测评解读
哈尔滨的信息系统安全等级保护测评(简称“等保测评”)是中国网络安全法规的一部分,旨在确保关键信息基础设施和其他重要信息系统的安全。下面是对哈尔滨等保测评的解读: 测评目的 等保测评的主要目的是评估信息系统是否满足国家规…...
python接口自动化的脚本
使用Requests库进行GET请求 Requests是Python中最常用的HTTP库,用于发送HTTP请求。下面是一个简单的GET请求示例,用于从API获取数据。 import requests url = "https://api.example.com/data" response = requests.get(url) if response.status_code == 200:prin…...
pdf转换成cad,这几个cad转换小妙招快码住!
在数字设计领域,PDF(Portable Document Format)和CAD(Computer-Aided Design)文件格式各有其独特之处。PDF常用于文件共享和打印,而CAD则是工程师和设计师们进行精确绘图和建模的必备工具。然而,…...
计算机组成原理——系统总线
题目:计算机使用总线结构便于增减外设,同时__C____。 A.减少了信息传送量 B.提高了信息传输速度 C.减少了信息传输线的条数 1. 总线的分类 1.1. 片内总线 芯片内部的总线 在CPU芯片内部,寄存器与寄存器之间、寄存器与逻辑单元ALU之间 1.1.1. 数据总线 双向传输总线 数…...
2024年6月大众点评广州餐饮店铺POI分析20万家
2024年6月大众点评广州餐饮店铺POI共有199175家 店铺POI点位示例: 店铺id k9uiFADtAvs9EdPC 店铺名称 点都德(聚福楼店) 十分制服务评分 8.6 十分制环境评分 8.3 十分制划算评分 8.5 人均价格 77 评价数量 41673 店铺地址 惠福东路470号(富临食府对面) 大…...
【最佳实践】前端如何搭建自己的cli命令行工具,让自己编码的时候如虎添翼
作为前端开发人员,搭建自己的前端CLI工具是一个有趣且有意义的事情。以下是一篇详细的教程,包括使用场景和案例。 使用场景 假设你是一个前端团队的一员,需要频繁地在不同的项目中执行一些标准化的任务,比如: 根据模…...
未来一周比特币价格及数字货币市场预测
荷月的比特币市场就像过山车一样,仅仅六月下旬就跌去-12%,本周更是暴跌-6%,至 58,378美元。在这种市场表现,应有的踩踏如期而至。德国政府今日宣布再出售750 比特币的行为继续打击多头,但是小编认为这恰恰预示着市场可…...
Qt Quick 教程(二)
文章目录 今天分析一段代码1. 注册单例类型2. 注册普通QML类型3. 注册C++类型到Qt元对象系统4.总结,具体解释5.如何在QML中使用这些注册的类型参考今天分析一段代码 // Register typesqmlRegisterSingletonType(QUrl("qrc:/StyleSheet.qml"), "Librum.style&qu…...
10个实用的Python编程实例,助你快速掌握Python技巧!
作为一门简洁易学且强大的编程语言,Python广泛应用于各个领域。本文将向大家介绍10个实用的Python编程实例,通过详细的实例代码帮助读者快速掌握Python的基础知识和常用技巧。 1. 计算阶乘 def factorial(n):if n 0:return 1else:return n * factorial…...
为什么要本地化您的多媒体内容?
当我们访问网站、应用程序和社交媒体时,体验不再局限于陈旧的文本和静态图像。现代处理能力和连接速度提高了快速加载视频、音频和动画的可能性。 这一切都提供了更具沉浸感和互动性的用户体验。多媒体是数字营销中最有效的内容之一,因为它对用户更具吸…...
MMCV【mmclassification】 从0到1 之 Docker 容器环境搭建步骤总结
🥇 版权: 本文由【墨理学AI】原创首发、各位读者大大、敬请查阅、感谢三连 🎉 声明: 作为全网 AI 领域 干货最多的博主之一,❤️ 不负光阴不负卿 ❤️ 文章目录 📙 Linux 下 Docker 安装环境检查Docker 安装 [ root 或者 sudo 权限用户可安装 ]给 普通用户 加入 Docker …...
深入探索Jetpack数据绑定(DataBinding)
Jetpack的数据绑定(DataBinding)库为我们提供了一个强大而灵活的工具,用于将UI组件与数据源绑定在一起。本文将深入探讨数据绑定的高级用法,包括双向绑定、自定义Binding Adapter、使用LiveData和ViewModel,以及如何处…...
vivado CELL_BLOAT_FACTOR、CFGBVS
CELL_BLOAT_FACTOR CELL_BLOAT_FACTOR属性用于指定添加“空白”或 增加单元格间距以增加分层单元格之间的放置距离 单元Vivado放置器会将模块中的单元隔开,以改善路由结果 设计。 当模块中的单元放置在一起时,可以使用单元膨胀,并且 从而在放…...
Linux—进程与计划管理
目录 一、程序 二、进程 1、什么是进程 2、进程的特点 3、进程、线程、携程 3.1、进程 3.2、线程 3.3、携程 三、查看进程信息 1、ps -aux 2、ps -elf 3、top 3.2、输出内容详解 3.2.1、输出第一部分解释 3.2.2、输出第二部分解释 4、pgrep 5、pstree 四、进…...
整数智能与上海数据交易所携手,共筑数据要素市场新篇章
近期,整数智能荣获上海数据交易所“数据治理服务商”证书,正式加入上海数据交易所数商生态,成为上海数据交易所官方认证的数据治理服务商。 在数字经济的浪潮中,上海数据交易所一直扮演着引领者和推动者的角色。紧扣建设国家级…...
计算机网络-自顶向下方法复习纲要
计算机网络-自顶向下方法复习纲要 第一章:计算机网络和因特网 协议:p6网络边缘:p6网络核心:p15存储转发传输机制:p16电路转发中的复用:p19-p20分组交换和电路交换的区别/对比:p18/p20分组交换…...
多模态2025:技术路线“神仙打架”,视频生成冲上云霄
文|魏琳华 编|王一粟 一场大会,聚集了中国多模态大模型的“半壁江山”。 智源大会2025为期两天的论坛中,汇集了学界、创业公司和大厂等三方的热门选手,关于多模态的集中讨论达到了前所未有的热度。其中,…...
Python:操作 Excel 折叠
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...
基于Docker Compose部署Java微服务项目
一. 创建根项目 根项目(父项目)主要用于依赖管理 一些需要注意的点: 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件,否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...
大模型多显卡多服务器并行计算方法与实践指南
一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...
IT供电系统绝缘监测及故障定位解决方案
随着新能源的快速发展,光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域,IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选,但在长期运行中,例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...
html-<abbr> 缩写或首字母缩略词
定义与作用 <abbr> 标签用于表示缩写或首字母缩略词,它可以帮助用户更好地理解缩写的含义,尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时,会显示一个提示框。 示例&#x…...
苹果AI眼镜:从“工具”到“社交姿态”的范式革命——重新定义AI交互入口的未来机会
在2025年的AI硬件浪潮中,苹果AI眼镜(Apple Glasses)正在引发一场关于“人机交互形态”的深度思考。它并非简单地替代AirPods或Apple Watch,而是开辟了一个全新的、日常可接受的AI入口。其核心价值不在于功能的堆叠,而在于如何通过形态设计打破社交壁垒,成为用户“全天佩戴…...
永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器
一、原理介绍 传统滑模观测器采用如下结构: 传统SMO中LPF会带来相位延迟和幅值衰减,并且需要额外的相位补偿。 采用扩展卡尔曼滤波器代替常用低通滤波器(LPF),可以去除高次谐波,并且不用相位补偿就可以获得一个误差较小的转子位…...
【UE5 C++】通过文件对话框获取选择文件的路径
目录 效果 步骤 源码 效果 步骤 1. 在“xxx.Build.cs”中添加需要使用的模块 ,这里主要使用“DesktopPlatform”模块 2. 添加后闭UE编辑器,右键点击 .uproject 文件,选择 "Generate Visual Studio project files",重…...
LangChain 中的文档加载器(Loader)与文本切分器(Splitter)详解《二》
🧠 LangChain 中 TextSplitter 的使用详解:从基础到进阶(附代码) 一、前言 在处理大规模文本数据时,特别是在构建知识库或进行大模型训练与推理时,文本切分(Text Splitting) 是一个…...
