c进阶测试题

选择题

1.请问该程序的输出是多少(C)

#include<stdio.h>
int main(){unsigned char i = 7;int j = 0;for(;i > 0;i -= 3){
++j;}
printf("%d\n", j);return 0;
}

A. 2
B. 死循环
C. 173
D. 172
首先unsigned char型是不会为负数,那这个题的意思就是看i=7是一直进行-3操作,j++,打印j,最后i=0,此时j等于几,那么我们直接来分析一下。
在这里插入图片描述
就是这样一个循环那么i=7进行减等操作,即为n个256+7整除3即可(n为最小值,0也是一个数,不要忽略了),得出的答案是173。

2.以下程序运行时,若输入1abcedf2df<回车>输出结果是(C)


#include <stdio.h>
int main() {char a = 0, ch;while ((ch = getchar()) != '\n') {if (a % 2 != 0 && (ch >= 'a' && ch <= 'z')ch = ch - 'a' + 'A';a++;putchar(ch);}printf("\n");return 0;
}

A. 1abcedf2df
B. 1ABCEDF2DF
C. 1AbCeDf2dF
D. 1abceDF2DF
在这里插入图片描述

所以在1,3,5,7,9下标的字母会变成大写。

3.以下哪个选项一定可以将flag的第二个bit置0(A)
A. flag&=~2
B. flag|=2
C. flag^=2
D. flag>>=2
这个就不过多解释了,很简单的一道题,如果不清楚可以看作者的原反补码

4.下面两个结构体

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

在#pragma pack(4)和#pragma pack(8)的情况下,结构体的大小分别是(C)
A. 16 24,16 24
B. 16 20,16 20
C. 16 16,16 24
D. 16 16,24 24

在这里插入图片描述我们先看pack为4 的情况
这个是结构体1的情况,默认对齐数是4,所以每个变量放到4的整数倍即可,可以知道此时的结构体内存大小是16

这个是结构体2的情况在这里插入图片描述
因为默认对齐数是4,所以每个变量放到4的整数倍即可,可以知道此时的结构体内存大小是16

接下来看pack为8的情况:
结构体1:
在这里插入图片描述
依然是16

结构体2:
在这里插入图片描述
用了19个字节,应该为8的整数倍所以是24.

5.下列C程序执行后c输出结果为(A)(32位)

#include<stdio.h>
#include<stdlib.h>
void main()
{int a = -3;unsigned int b = 2;long c = a + b;printf("%ld\n", c);
}

A. -1
B. 4294967295
C. 0x7FFFFFFF
D. 0xFFFFFFFF

这道题十分的简单,-3+2=-1,这个没什么好解释的。

6.设有定义char *p[]={“Shanghai”,“Beijing”,“Honkong”};则结果为j字符的表达式是(B)
A. *p[1] +3
B. *(p[1] +3)
C. *(p[3] +1)
D. p[3] [1]

在这里插入图片描述
首先可以知道不是D和C,B是正确的,A选项p[1]是指向B,解引用就是B,加3就是E,所以不对。

7.执行如上函数后. i的值为()

int f(int x){
return ((x>2) ? x*f(x-1) : 3);
}
int i;
i=f(f(2));

A. 30
B. 无限递归
C. 9
D. 2160

在这里插入图片描述

8.在

int p[][4] = {{1}, {3, 2}, {4, 5, 6}, {0}};

中,p[1][2]的值是(B)
A. 1
B. 0
C. 6
D. 2
在这里插入图片描述

9.fun(21)运行结果是(A)

int fun(int a){
a^=(1<<5)-1;
return a;
}

A. 10
B. 5
C. 3
D. 8

在这里插入图片描述

10.下列关于C/C++的宏定义,不正确的是(B)
A. 宏定义不检查参数正确性,会有安全隐患
B. 宏定义的常量更容易理解,如果可以使用宏定义常量的话,要避免使用const常量
C. 宏的嵌套定义过多会影响程序的可读性,而且很容易出错
D. 相对于函数调用,宏定义可以提高程序的运行效率

ACD都是宏定义的优点或者缺点,小伙伴有疑问可以看作者编译链接那篇博客详细了解一下。

11.下面关于"指针"的描述不正确的是(A)
A. 当使用free释放掉一个指针内容后,指针变量的值被置为NULL
B. 32位系统下任何类型指针的长度都是4个字节
C. 指针的数据类型声明的是指针实际指向内容的数据类型
D. 野指针是指向未分配或者已经释放的内存地址

当我们free释放掉一个指针指向的动态空间,指针并不会被置为NULL,一般都是我们手动输入令指针等于NULL。

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

这个同样不是很熟悉的可以看一下编译链接那篇博客,详细了解一下

13.设有以下宏定义:

#define N 3+1
#define Y(n) ((N+1)*n)

则执行语句 z=2*(N+Y(5+1))后,z 的值为(A)
A. 60
B. 190
C. 248
D. 上述答案都不对

在这里插入图片描述

编程题

题目描述:对于一个较大的整数 N(1<=N<=2,000,000,000)
比如 980364535,我们常常需要一位一位数这个数字是几位数,但是如果在这 个数字每三位加一个逗号,它会变得更加易于朗读。
因此,这个数字加上逗号成如下的模样:980,364,535请写一个程序帮她完成这件事情
输入描述:一行一个整数 N
输出描述:一行一个字符串表示添加完逗号的结果
补充说明:1≤n≤2,000,000,000

#include<stdio.h>
int main()
{char str[14] = { 0 };int N = 0;scanf("%d", &N);int i = 0;int k = 0;while (N)//存放循环{if (k != 0 && k % 3 == 0)//存放逗号,首先首元素不能存放所以k!=0,其次每存放3个数字存放一个逗号,所以k%3==0{str[i++] = ',';//存放逗号}str[i++] = N % 10+'0';//将N对10取余后加'0'转变为字符型数字存放到数组中后i++N /= 10;//取下一位余数需要除10k++;//记录存放个数}for (i--; i >= 0; i--)//倒打印循环{printf("%c", str[i]);}return 0;
}

只说一下思路,具体解释看注释,我们把输入的N值一位一位的变成字符型的数字,存放到str数组中,每存放三位存放一个逗号,之后倒着打印即可。

2.题目描述:输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。
例如:第一个字符串是"They are students.“,第二个字符串是”aeiou”。删除之后的第一个字符串变成"Thy r stdnts."。
保证两个字符串的长度均不超过100。
输入描述:输入两行,每行一个字符串。
输出描述:输出删除后的字符串。

#include<stdio.h>
int is_find(char ptr1, char* ptr2)//接受参数为一个字符和一个char型指针
{while (*ptr2)//遍历该指针{if (ptr1 == *ptr2)//如果该字符等于该指针指向的字符返回值为1return 1;ptr2++;//指针向后移动,进行下一次循环}return 0;//循环完毕,说明没有出现,返回值为0
}
int main()
{char str1[101] = { 0 };char str2[101] = { 0 };gets(str1);gets(str2);int i = 0;while (str1[i])//循环str1{if (is_find(str1[i], str2) == 0)//传参为str1的第i个元素,和str2数组名,设置返回值为0来接受{printf("%c", str1[i]);//如果没有出现就打印}i++;//进行下一次循环}return 0;
}

首先,我们可以想到在str2中出现过的str1并不会被打印,所以我们直接循环遍历str1,如果出现就不打印,在这里我们单独封装一个is_find函数来执行这个功能,具体解释请看注释。

今天分享就到这里为止,谢谢大家。

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

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

相关文章

flask入门(四)前后端数据传输

文章目录 1、flask后端接收来自前端的数据1&#xff09;如果前端提交的方法为POST2&#xff09;如果前段提交的方法是GET 2、flask后端向前端传数据3、案例参考文献 1、flask后端接收来自前端的数据 1&#xff09;如果前端提交的方法为POST 后端接收时的代码&#xff1a; xx…

pojo之vo_dto_po的一些理解

一次扫盲VO、DTO、DO和PO区别、用法、概念~-腾讯云开发者社区-腾讯云 (tencent.com) Java学习笔记——实体类&#xff08;ENTITY&#xff0c;VO&#xff0c;DTO&#xff0c;BO&#xff09;_dto继承entity_路言汐的博客-CSDN博客 说清楚PO、DTO、VO、BO与使用场景_业务逻辑层p…

nvm 常用命令

记录一下常使用的nvm命令&#xff0c;希望对大家也有所帮助&#xff01;&#xff01;&#xff01; nvm 帮助 nvm --help 版本查询 nvm -v 查看可用node版本 nvm list 下载最新node nvm install node 使用v21.0.0版本的node nvm use v21.0.0 切换node默认版本 nvm alias …

我试图扯掉这条 SQL 的底裤。只能扯一点点,不能扯多了

之前不是写分页嘛,分页肯定就要说到 limit 关键字嘛。 然后我啪的一下扔了一个链接出来: https://dev.mysql.com/doc/refman/8.0/en/limit-optimization.html 这个链接就是 MySQL 官方文档,这一章节叫做“对 Limit 查询的优化”,针对 limit 和 order by 组合的场景进行了较…

【MySQL】存储引擎

存储引擎 查看存储引擎设置表的存储引擎创建表时指定存储引擎修改表的存储引擎 引擎介绍InnoDB引擎: 具备外键支持的十五存储引擎MyISAM引擎: 主要的非事务处理存储引擎Archive引擎: 用于数据存档Blackhole引擎: 丢弃写操作,读操作返回空内容CSV引擎: 读取数据时,以逗号分隔各个…

软件设计原则-依赖倒置原则讲解以及代码示例

依赖倒置原则 一&#xff0c;介绍 1.前言 依赖倒置原则&#xff08;Dependency Inversion Principle&#xff0c;DIP&#xff09;是面向对象设计中的一个重要原则&#xff0c;由Robert C. Martin提出。 依赖倒置原则的核心思想是&#xff1a;高层模块不应该依赖于低层模块&…

aiohttp ssl.SSLError: [SSL: SSLV3_ALERT_HANDSHAKE_FAILURE] 错误处理

这个问题原因吧其实就是3.10 开始官网更新了TLS 堆栈默认安全设置 感兴趣的可以看下链接 python官网叙述: Python 3.10 增加了 TLS 堆栈的默认安全设置 解决也很简单&#xff0c;将ssl安全等级降下来就行&#xff0c;例如&#xff1a; import ssl import aiohttp ctx ssl.cr…

Redis 底层对 String 的 3 个优化

Redis对 String 类型实现了很多优化&#xff0c;通过以下三个重要的优化点来解释&#xff1a; 1. 简单动态字符串&#xff08;SDS&#xff09; Redis 的 String 类型内部采用简单动态字符串&#xff08;SDS&#xff09;来管理字符串。相比于 C 语言的原生字符串&#xff0c;S…

二、【MyBatis】 MyBatis入门与简单使用

二、【MyBatis】 MyBatis入门与简单使用 二、【MyBatis】 MyBatis入门与简单使用一、什么是ORM二、为什么mybatis是半自动的ORM框架2.1 Hibernate优点2.2 Hibernate缺点2.3 MyBatis与Hibernate区别三、Mybatis快速入门3.1 项目引入Maven相关依赖3.2 创建测试数据库3.3 编写数据…

sealos一键部署K8S环境(sealos3.0时代教程过时了,目前已经4.0了,请移步使用Sealos一键安装K8S)

1 安装Sealos(4.0版本) sealos部署k8s贼方便&#xff0c;只需要一条init命令即可&#xff0c;3分钟部署完&#xff08;下载安装包的时间不算&#xff09;。 官方教程&#xff1a;https://www.sealyun.com/instructions/1st #主机名&#xff1a; hostnamectl set-hostname mas…

PROSTATEx-2 上前列腺癌的 3D CNN 分类

内容 本文介绍了在多参数 MRI 序列上使用 3D CNN 对前列腺癌进行显着性或不显着性分类。内容如下: 数据集描述Dicom 到 Nifti 文件格式的转换不同 MRI 序列的联合配准

redis底层数据结构

总所周知&#xff0c;redis支持五种数据类型String、Hash、List、Set、ZSet。在支持这些复杂数据结构的同时&#xff0c;redis不仅需要保证读写的性能&#xff0c;还能提供各种微操作&#xff0c;比如直接修改Hash字典中的某个field的值&#xff0c;或者直接往ZSet中插入某个值…

【人工智能Ⅰ】2-知识表示

【人工智能Ⅰ】2-知识表示 知识是智能的基础 一阶谓词逻辑、产生式、框架等知识表示方法 文章目录 【人工智能Ⅰ】2-知识表示2.1 知识与知识表示的概念知识的概念知识的特性 2.2 一阶谓词逻辑表示法谓词谓词公式一阶谓词逻辑知识表示方法一阶谓词逻辑表示法的特点 2.3 产生式…

Failed to start The nginx HTTP and reverse proxy server.

本章教程主要分享一下&#xff0c;当nginx 启动时&#xff0c;遇到报这个错误时的一个解决问题思路。 目录 1、观察报错信息 2、尝试性解决 1、观察报错信息 根据日志的信息&#xff0c;我们至少可以知道2个比较信息。 1、操作用户执行命令是在非root权限下进行操作的。 2、Ad…

Xcode14创建github远程仓库Token

1.点击Create a Token on GitHub 2.在打开的网页中,登陆GitHub 3.点击生成Token 这是不能为空 4.Token创建成功如下: 5.复制Token到Xcode然后点击Sign In登陆 正在创建远程我仓库 正在将本地仓库代码推入远程仓库 创建成功

C++项目——云备份-②-第三方库认识

文章目录 专栏导读1. json 认识1.1 JSON 数据结构的特点 2. jsoncpp库认识3. json实现序列化案例4. json实现反序列化案例5. bundle文件压缩库认识6. bundle库实现文件压缩案例7.bundle库实现文件解压缩案例8.httplib库认识9. httplib库搭建简单服务器案例10. httplib库搭建简单…

YOLO目标检测——密集人群人头检测数据集【含对应voc、coco和yolo三种格式标签】

实际项目应用&#xff1a;在公共场所&#xff0c;如车站、商场、景区等&#xff0c;可以通过人头目标检测技术来监测人群流量数据集说明&#xff1a;人头检测数据集&#xff0c;真实场景的高质量图片数据&#xff0c;数据场景丰富标签说明&#xff1a;使用lableimg标注软件标注…

聊聊KafkaListener的实现机制

序 本文只要研究一下KafkaListener的实现机制 KafkaListener org/springframework/kafka/annotation/KafkaListener.java Target({ ElementType.TYPE, ElementType.METHOD, ElementType.ANNOTATION_TYPE }) Retention(RetentionPolicy.RUNTIME) MessageMapping Documented …

python实现excel的数据提取

一文带你实现excel表格的数据提取 今天记录一下如何使用python提取Excel中符合特定条件的数据 在数据处理和分析的过程中&#xff0c;我们经常需要从Excel表格中提取特定条件下的数据。Python的pandas库为我们提供了方便的方法来进行数据查询和过滤。 Pandas 是 Python 语言…

SELECT COUNT(*) 会造成全表扫描吗?

前言 SELECT COUNT(*)会不会导致全表扫描引起慢查询呢&#xff1f; SELECT COUNT(*) FROM SomeTable 网上有一种说法&#xff0c;针对无 where_clause 的 COUNT(*)&#xff0c;MySQL 是有优化的&#xff0c;优化器会选择成本最小的辅助索引查询计数&#xff0c;其实反而性能…