【C刷题】day5

一、选择题
1、如下程序的功能是( )
#include <stdio.h>
int main()
{char ch[80] = "123abcdEFG*&";int j;puts(ch);for(j = 0; ch[j] != '\0'; j++)if(ch[j] >= 'A' && ch[j] <= 'Z')ch[j] = ch[j] + 'e' - 'E';puts(ch);return 0;
}

A: 测字符数组ch的长度

B: 将数字字符串ch转换成十进制数

C: 将字符数组ch中的小写字母转换成大写

D: 将字符数组ch中的大写字母转换成小写

【答案】:

D

【解析】:

考点:大小写转换(ASCII值)一个字母对应的小写比大写的ASCII码值大32

'e'和'E'之间的ASCII码值相差32(ch[j]+'e'-'E'相当于ch[j]+32)。一个字母从大写转化为小写就是在它自身上+32,小写转大写则是-32


2、对于代码段,下面描述正确的是( )
t=0;
while(printf("*"))
{t++;if (t<3)break;
}

 A: 其中循环控制表达式与0等价 B: 其中循环控制表达式与'0'等价

C: 其中循环控制表达式是不合法的 D: 以上说法都不对

【答案】:

B

【解析】:

考点:‘0’表示真,并不是0

printf(“*”)函数调用的返回值是字符串中字符的个数,即为1。

所以while后面的条件恒为真,所以循环控制表达式与'0'是等价的(字符'0'不是0)


3、以下程序运行时,若输入 1abcedf2df<回车> 输出结果是( )
#include <stdio.h>
int main()
{char ch;while ((ch = getchar()) != '\n'){if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z'))ch = ch - 'a' + 'A';putchar(ch);}printf("\n");return 0;
}

A: 1abcedf2df B: 1ABCEDF2DF C: 1AbCEdf2df D: 1aBceDF2DF

【答案】:

C

【解析】:

考点:大小写转换(ASCII值)'a'的ACSII值为97,'A'的ASCII值为65

程序首先考虑ch的ASCII码值是不是奇数,再看是不是小写字母,同时满足时被改为大写字母


4、下列条件语句中,功能与其他语句不同的是( )

A: if(a) printf("%d\n",x); else printf("%d\n",y); B: if(a==0) printf("%d\n",y); else printf("%d\n",x);

C: if (a!=0) printf("%d\n",x); else printf("%d\n",y); D: if(a==0) printf("%d\n",x); else printf("%d\n",y);

【答案】:

D

【解析】:

考点:if语句中a省略相当于a!=0

D选项与众不同,其他都是a==0时输出y,a!=0时输出x


5、我们知道C语言的 break 语句只能跳出离它最近的一层循环,可是有时候我们需要跳出多层循环,下列跳出多层循环的做法正确的是【多选】( )

A: 将程序写成函数用return结束函数,便可跳出循环

B: 修改外层循环条件例如

for( int i = 0 ; i < MAX1 ; i ++ )
{for( int j = 0 ; j < MAX2 ; j ++ ){if( condition ){i = MAX1;break;}}
}

C: 在外层循环设置判断条件例如


for( ; symbol != 1 && condition2 ; )
{for( ; symbol != 1 && condition3 ; ){if( condition1 )symbol = 1 ;}
}

D: 在外层循环后面加入break例如

for( ; condition2 ; )
{for( ; condition3 ; ){if( condition1 )symbol = 1 ;} if(symbol == 1 )break ;
}

【答案】:

ABCD

【解析】:

考点:跳出多层循环的方法

跳出多层循环的方法:

(1)goto语句(把控制无条件转移到同一函数内的被标记的语句)

goto end;

....

end:statement;

(2) 程序写成函数用return结束函数

(3)设置条件使外层循环条件不成立,再+break跳出内层循环

(4)在内层循环让flag为1,在跳出内层循环进入外层循环时如果flag==1,就break跳出


二、编程题

1.数字在升序数组中出现的次数

【参考答案】: 

考察二分查找:需要找出等于k的上界leftbound和下界rightbound

注意:

(1)同时需要考虑特殊情况:k不在nums的范围内,这个时候计算上下界没有意义

(2)在找下界时,其中一个mid要+1,不然当nums为【3,3,3,3】无法跳出循环

int GetNumberOfK(int* nums, int numsLen, int k ) {int rightbound = 0;int leftbound = 0;int left = 0;int right = numsLen - 1;int mid = 0;//k不在nums的范围内if (nums[0] > k || nums[numsLen - 1] < k)return 0;//k在nums的范围内else {//找下界while (left < right) {//这里的mid要+1,不然当nums为【3,3,3,3】无法跳出循环mid = (left + right) / 2+1;if (nums[mid] > k) {right = mid - 1;} else {left = mid;}}rightbound = right;//left和right恢复原值left = 0;right = numsLen - 1;//找上界while (left < right) {mid = (left + right) / 2;if (nums[mid] >= k) {right = mid;} else {left = mid + 1;}}leftbound = left;return rightbound - leftbound + 1;}}

2. 整数转换

 【参考答案】: 

方法一:取出A和B每一位二进制数(&1),不一样就count++

注意这里((A>>i)&1)外层括号要加,因为!=的优先级高于&

int convertInteger(int A, int B)
{int count=0;for(int i=0;i<32;i++){if(((A>>i)&1)!=((B>>i)&1)){count++;}}return count;
}

方法二:先A^B(如果对应位上数值相同则为1,不同则为0),如果再取出C的每一位上的二进制数,如果是1就count++

int convertInteger(int A, int B)
{int count=0;int C=A^B;for(int i=0;i<32;i++){if(((C>>i)&1)==1){count++;}}return count;
}

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

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

相关文章

visual studio安装时候修改共享组件、工具和SDK路径方法

安装了VsStudio后,如果自己修改了Shared路径&#xff0c;当卸载旧版本&#xff0c;需要安装新版本时发现&#xff0c;之前的Shared路径无法进行修改&#xff0c;这就很坑爹了&#xff0c;因为我运行flutter程序的时候&#xff0c;报错找不到windows sdk的位置&#xff0c;所以我…

E053-web安全应用-Brute force暴力破解初级

课程分类&#xff1a; web安全应用 实验等级: 中级 任务场景: 【任务场景】 小王接到磐石公司的邀请&#xff0c;对该公司旗下的网站进行安全检测&#xff0c;经过一番检查发现该论坛的后台登录页面上可能存在万能密码漏洞&#xff0c;导致不知道账号密码也能登录后台&am…

基于适应度相关优化的BP神经网络(分类应用) - 附代码

基于适应度相关优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于适应度相关优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.适应度相关优化BP神经网络3.1 BP神经网络参数设置3.2 适应度相关算法应用 4…

springboot配置swagger

springboot配置swagger Swagger 是什么Swagger配置springboot代码展示总结 Swagger 是什么 Swagger 是一个用于构建、文档和调用 RESTful Web 服务的强大工具。它提供了以下几方面的好处&#xff1a; 自动生成 API 文档: Swagger 可以自动生成 API 文档&#xff0c;包括接口的…

圣树唤歌最强阵容2023,圣树唤歌阵容推荐

无疑圣树唤歌作为一款备受欢迎的手机游戏&#xff0c;其深刻的战斗系统一直以来都受到大家的追捧。在这个虚拟世界中胜利的关键在于组建一支无懈可击的强大队伍&#xff0c;要想成为强者&#xff0c;就必须拥有最强阵容。 关注【娱乐天梯】&#xff0c;获取内部福利号 在本篇攻…

什么是云原生?零基础学云原生难吗?

伴随着云计算的浪潮&#xff0c;云原生概念也应运而生&#xff0c;而且火得一塌糊涂&#xff0c;但真正谈起“云原生”&#xff0c;大多数非 IT 从业者的认知往往仅限于将服务应用放入云端&#xff0c;在云上处理业务。实际上&#xff0c;云原生远不止于此。 现在越来越多的企…

【JVM】JVM的垃圾回收机制

JVM的垃圾回收机制 对象死亡判断方法引用计数算法可达性分析算法 垃圾回收算法标记清除法复制算法标记整理算法分代算法 Java运行时内存的各个区域,对于程序计数器,虚拟机栈,本地方法栈这三个部分区域而言,其生命周期与相关线程有关,随线程而生,随线程而灭,并且这三个区域的内存…

[python 刷题] 143 Reorder List

[python 刷题] 143 Reorder List 题目&#xff1a; You are given the head of a singly linked-list. The list can be represented as: L 0 → L 1 → … → L n − 1 → L n L_0 → L_1 → … → L_{n - 1} → L_n L0​→L1​→…→Ln−1​→Ln​ Reorder the list to be o…

收集Stream流

Stream流的收集操作 收集Stream流的含义&#xff1a;就是把Stream流操作后的结果数据 转回 到 集合 或者 数组 中去。Stream流&#xff1a;方便操作 集合 / 数组 的 手段。集合 / 数组&#xff1a;才是开发中的 目的 。 Stream流的收集方法 R collect&#xff08;Collector co…

React create-react-app 里配置代理(解决跨域)

配置代理&#xff1a; creact-react-app v5 当然不是v5 下面的方法也适用。 方式一&#xff1a;package.json里配置 其实 cra里给了个简单的配置代理 就是在package.json里加上proxy就行了。 修改时需要 npm start重新运行一下&#xff0c;要不然可能不生效。 proxy只能以 h…

基于springboot实现酒店管理系统平台项目【项目源码+论文说明】计算机毕业设计

摘要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们所认识&#xff0c;科学化的管理&#xff0c;使信息存…

LeetCode【74】搜索二维矩阵

题目&#xff1a; 代码&#xff1a; public static boolean searchMatrix(int[][] matrix, int target) {int rows matrix.length;int columns matrix[0].length;// 先找到行&#xff0c;行为当前行第一列<target&#xff0c;当前行1行&#xff0c;第一列>targetfor…