37-巩固练习(一)

37-1 if语句等

1、问:输出结果

int main()
{int i = 0;for (i = 0; i < 10; i++){if (i = 5){printf("%d\n", i);}return 0;}
}

答:一直输出5,死循环

解析:i=5是赋值语句,不是判断语句,每一次循环i都被赋值为5,每一次都打印5;每一次循环i都被赋值为5,加1后是6,永远小于10,要一直循环下去

2、问:关于if语句说法正确是:()

A.if语句后面只能跟一条语句
B.if语句中0表示假,1表示真
C.if语句是一种分支语句,可以实现单分支,也可以实现多分支 
D.else语句总是和它的对齐的if语句匹配

答:C

解析:B:0表示假,非0表示真,并不只有1

3、关于switch说法不正确的是()

A.switct语句中的default子句可以放在任意位置
B.switch语句中case后的表达式只能是整形常量表达式
C.switch语句中case子句必须在default子句之前
D.switch语句中case表达式不要求顺序

答:C

解析:default与case的顺序不作要求;char也是属于整型家族的,因为字符存储的时候,存储的是ASCII码值

4、问:func(1)是多少?

int func(int a)
{int b;switch (a){case 1:b = 30;case 2:b = 20;case 3:b = 16;default:b = 0;}return b;
}

答:0

解析:没有break

5、问:switch(c)语句中,c不可以是什么类型()

A.int   B.Jong   C.char   D .float

答:D

6、问:输出结果

int main()
{int x = 3;int y = 3;switch (x % 2){case 1:switch (y){case 0:printf("first");case 1:printf("second");break;default:printf("hello");}case 2:printf("third");}return 0;
}

 答:hellothird

解析:注意有无break

7、将三个整数按从大到小输出

代码1:

int main()
{int a = 0;int b = 0;int c = 0;scanf("%d%d%d", &a, &b, &c);if (a > b){if (a < c){printf("%d ", c);printf("%d ", a);printf("%d ", b);}else{if (a > c){if (b > c){printf("%d ", a);printf("%d ", b);printf("%d ", c);}else{printf("%d ", a);printf("%d ", c);printf("%d ", b);}}}}else{if (b < c){printf("%d ", c);printf("%d ", b);printf("%d ", a);}else{if (b > c){if (a > c){printf("%d ", b);printf("%d ", a);printf("%d ", c);}else{printf("%d ", b);printf("%d ", c);printf("%d ", a);}}}}return 0;
}

代码2(推荐):

int main()
{int a = 0;int b = 0;int c = 0;int tmp = 0;scanf("%d%d%d", &a, &b, &c);//调整,a放最大值,b放中间值,c放最小值if (a < b){tmp = a;a = b;b = tmp;}if (a < c){tmp = a;a = c;c = tmp;}if (b < c){tmp = b;b = c;c = tmp;}printf("%d %d %d", a, b, c);return 0;
}

 代码3(函数版):

void Swap(int* a, int* b)
{int tmp = 0;tmp = *a;*a = *b;*b = tmp;
}
int main()
{int a = 0;int b = 0;int c = 0;scanf("%d%d%d", &a, &b, &c);//调整,a放最大值,b放中间值,c放最小值if (a < b){Swap(&a, &b);}if (a < c){Swap(&a, &c);}if (b < c){Swap(&b, &c);}printf("%d %d %d", a, b, c);return 0;
}

8、写一个代码打印1-100之间所有3的倍数的数字

代码1:

int main()
{int i = 0;for (i = 3; i <= 100; i+=3){printf("%d ", i);}return 0;
}

代码2:

int main()
{int i = 0;for (i = 1; i <= 100; i++){if(i % 3 == 0)printf("%d ", i);}return 0;
}

9、求两个数的最大公约数

 代码1:暴力求解

int main()
{int a = 0;int b = 0;int tmp = 0;int i = 0;scanf("%d%d", &a, &b);if (a > b)  //让a是小的数{tmp = a;a = b;b = tmp;}for (i = a; i > 1; i--){if ((a % i == 0)&&(b % i == 0)){printf("最大公约数:%d\n", i);break;}}if (1 == i){printf("这两个数没有公约数");}return 0;
}

代码2:辗转相除法

两个整数的最大公约数是能够同时整除它们的最大的正整数。辗转相除法基于如下原理:两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。

int main()
{int a = 0;int b = 0;int c = 0;int tmp = 0;scanf("%d%d", &a, &b);while (c= a % b){a = b;b = c;}printf("%d\n", b);return 0;
}

a和b谁大谁小不影响,可以用a=18,b=24和a=24,b=18自己测试一下

37-2 for循环语句等

1、问:关于while(条件表达式)循环练以下叙述正确的是()?
(假设循环体里面没break,continue,return,goto等等语句)

A.循环体的执行次数总是比条件表达式的执行次数多一次
B.条件表达式的执行次数总是比循环体的执行次数多一次
C.条件表达式的执行次数与循环体的执行次数一样
D.条件表达式的执行次数与循环体的执行次数无关

答:B

2、问:输出结果

int main()
{int a = 0, b = 0;for (a = 1, b = 1; a <= 100; a++){if (b >= 20) break;if (b % 3 == 1){b = b + 3;continue;}b = b - 5;}printf("%d\n", a);return 0;
}

答:8

3、编程数一下1到100的所有整数中出现多少个数字9

注意:题目中说的是出现多少个9,而不是多少个数字包含9

int main()
{int i = 0;int count = 0;  //计数for (i = 1; i <= 100; i++){if (i / 10 == 9)  //十位是9{count++;}if (i % 10 == 9)  //个位是9{count++;}}printf("%d\n", count);return 0;
}

4、计算1/1-1/2+1/3-1/4+1/5......+ 1/99 - 1/100的值,打印出结果

代码1:

int main()
{int i = 0;double sum = 0;  //结果是小数for (i = 1; i <= 100; i++){if (i % 2 != 0){sum += 1.0 / i;  //要想得到小数,必须要有一个浮点数}else{sum += -1.0 / i;}}printf("%lf\n", sum);return 0;
}

代码2:

int main()
{int i = 0;double sum = 0;  //结果是小数int flag = 1;  //用于正负变换for (i = 1; i <= 100; i++){sum += (1.0 / i)*flag;flag = -flag;}printf("%lf\n", sum);return 0;
}

5、10个数找最大值

int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };int i = 0;int max = arr[0];for (i = 1; i < 10; i++){if (arr[i] > max){max = arr[i];}}printf("%d\n", max);return 0;
}

代码2(手动输入十个数)

int main()
{int arr[10] = { 0 };int j = 0;for (j = 0; j < 10; j++){scanf("%d", &arr[j]);}int i = 0;int max = arr[0];for (i = 1; i < 10; i++){if (arr[i] > max){max = arr[i];}}printf("%d\n", max);return 0;
}

6、 在屏幕上输出九九乘法表

代码1:

int main()
{int i = 0;//打印9行for (i = 1; i <= 9; i++){int j = 0;//打印一行for (j = 1; j <= i; j++){printf("%d*%d=%d ", i, j, i * j);}printf("\n");}return 0;
}

代码2: 

 %2d:右对齐;%-2d:左对齐

int main()
{int i = 0;for (i = 1; i <= 9; i++){int j = 0;for (j = 1; j <= i; j++){printf("%d*%d=%-2d ", i, j, i * j);}printf("\n");}return 0;
}

37-3 函数等

1、问:关于实参和形参描述错误的是()

A.形参是实参的一份临时拷贝
B.形参是在函数调用的时候才实例化。才开辟内存空间
C.改变形参就是改变实参
D.函数调用如果采用传值调用。改变形参不影响实参

答:C

2、问:函数调用exec(v1,v2),(v3,v4),v5,v6)中,实参的个数()

A .3   B.4   C.5   D.6

答:B

解析:表达式是一个实参

3、问:以下关于函数设计不正确的说法是()

A.函数设计应该追求高内聚低耦合
B.要尽可能多的使用全局变量
C.函数参数不易过多
D.设计函数时,尽量做到谁申请的资源就由谁来释放

答:B

解析:高内聚低耦合,功能单一,不要与其他的产生过多关联;过多使用全局变量,不安全。

4、问:关于C语言函数描述正确的是()

A.函数必须有参数和返回值
B.函数的实参只能是变量
C.库函数的使用必须要包含对应的头文件
D.有了库函数就不需要自定函数了

答:C

5、问:C语言规定,在一个源程序中,main函数的位置()

A.必须在最开始
B.必须在库函数的后面
C.可以任意
D.必须在最后

答:C

6、问:以下叙述中不正确的是()

A.在不同的阂数中可以使用相同名字的变量
B.函数中的形式参数是在栈中保存
C.在一个函数内定义的变量只在本函数范围内有效
D.在一个函数内复合语句中定义的变量在本函数范围内有效(复合语句指函数中的成对括号构成的代码)

答:D

解析:

7、 实现一个函数,打印乘法口诀表,口诀表的行数和列数自己指定

void print_table(int n)
{int i = 0;for (i = 1; i <= n; i++){int j = 0;for (j = 1; j <= i; j++){printf("%d*%d=%-2d ", i, j, i * j);}printf("\n");}
}
int main()
{int n = 0;scanf("%d", &n);print_table(n);return 0;
}

37-4 函数递归等 

1、问:能把函数处理结果的两个数据返回给主调函数,在下面的方法中不正确的是:()

A.return这两个数   B.形参用数组   C .形参用两个指针   D.用两个全局变量

答:A

解析:return只能返回一个数

2、问:关于函数调用说法不正境的是()

A.函数可以传值调用,传值调用的时候形参是实参的一份临时拷贝
B.函数可以传址调用,传址调用的时候。可以通过形参操作实参
C.函数可以嵌套定义,但是不能嵌套调用
D.函数可以嵌套调用,但是不能嵌套定义

答:C

3、问:在函数调用时,以下说法正确的是()

A.函数调用后必须带回返回值
B.实际参数和形式参数可以同名
C.函数间的数据传递不可以使用全局变量
D.主调函数和被调函数总是在同一个文件里

答:B

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

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

相关文章

路径规划——曲线拟合详解(一):多项式轨迹与QP优化(minimum-snap算法核心部分)

前言 历经一个多星期时间&#xff0c;我们在路径规划——搜索算法部分讲解了7种常见的路径搜索算法&#xff0c;每一种算法的链接放在下面了&#xff0c;有需要的朋友点击跳转即可&#xff1a; 路径规划——搜索算法详解&#xff08;一&#xff09;&#xff1a;Dijkstra算法详…

由平行公设的不同而来三种几何学浅谈

由平行公设的不同而来三种几何学浅谈 欧几里德的《几何原本》 欧几里德的《几何原本》一开始就给出了23个定义&#xff0c;5个公设&#xff0c;5个公理。 23个定义(部分)&#xff1a; 点是没有部分的东西。 线是没有宽度的长度。 线的端点是点。 直线是各点都在同一方向上…

GraalVM运行模式和企业级应用

文章目录 GraalVM运行模式JIT模式AOT模式 GraalVM的问题和解决方案GraalVM企业级应用传统架构的问题Serverless架构函数计算Serverless应用场景Serverless应用 GraalVM内存参数 GraalVM运行模式 JIT模式 JIT&#xff08; Just-In-Time &#xff09;模式 &#xff0c;即时编译模…

Ruby 之交租阶段信息生成

题目 我看了一下&#xff0c;这个题目应该不是什么机密&#xff0c;所以先放上来了。大概意思是根据合同信息生成交租阶段信息。 解答 要求是要使用 Ruby 生成交租阶段信息&#xff0c;由于时间比较仓促&#xff0c;变量名那些就用得随意了些。要点主要有下面这些&#xff1a…

【介绍什么是DDOS】

&#x1f308;个人主页:程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

Qt 的发展历史、现状与启示

Qt 最早在1991年由挪威的两位程序员 Eirik Chambe-Eng 和 Haavard Nord 开发&#xff0c;他们在1994年创立 Trolltech 公司&#xff08;奇趣科技&#xff09;正式经营软件业务。Qt 的第一个公众预览版于1995年面世&#xff0c;之后在2008年被诺基亚收购&#xff1b;2011年到201…

Go——函数

一. 函数定义 1.1 特点 无需声明原型支持不定变参支持多返回值支持命名返回参数支持匿名函数和闭包函数也是一种类型&#xff0c;一种函数可以赋值给变量不支持嵌套&#xff0c;一个包不能有两个名字一样的函数不支持重载不支持默认参数 1.2 函数声明 函数声明包含一个函数名&…

备战蓝桥杯---DP刷题2

1.树形DP&#xff1a; 即问那几个点在树的直径上&#xff0c;类似ROAD那题&#xff0c;我们先求一下每一个子树根的子树的最大值与次大值用d1,d2表示&#xff0c;直径就是d1d2的最大值&#xff0c;那么我们如何判断是否在最大路径上&#xff0c;其实就是看一下从某一点出发的所…

还得是抖音,字节推出竖屏视频理解数据集,入选CVPR2024

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了免费的人工智能中文站https://ai.weoknow.com 新建了收费的人工智能中文站https://ai.hzytsoft.cn/ 更多资源欢迎关注 短视频在当下社交媒体逐渐成为主导的视频格式。传统视频处理技术和研究一般都专注于横屏视频…

58商铺全新UI试客试用平台网站php源码

探索未来商铺新纪元&#xff0c;58商铺全新UI试客试用平台网站PHP源码完整版震撼来袭&#xff01; 在这个数字化飞速发展的时代&#xff0c;58商铺一直致力于为商家和消费者打造更加便捷、高效的交易平台。今天&#xff0c;我们荣幸地推出全新UI试客试用平台网站PHP源码完整版…

C/C++ 项目:分别用精密星历和广播星历计算卫星坐标

文章目录 Part.I IntroductionChap.I rinex.hChap.II gmain_body.h Part.II 使用方法扩展阅读 Part.I Introduction 本文将介绍一个小项目的使用方法&#xff0c;此项目可用精密星历和广播星历计算卫星位置&#xff0c;并将两者结果做差&#xff0c;输出至文件。 其实 『分别…

SWM341系列应用(上位机应用)

SWM341系列之上位机应用 1、分级图像和PNG、JPG的应用 现象&#xff1a;客户使用SWM34SVET6HMI_0.4.1版本上位机进行UI界面布局&#xff0c;反馈在模拟运行时&#xff08;PC端&#xff09;流畅&#xff0c;在Demo平台&#xff08;设备端&#xff09;运行卡顿。 分析及解决&…

【fastadmin】脚本模式下,日志钩子函数执行出现死循环,导致内存溢出奔溃

问题出现原因是想对项目中error级别的日志&#xff0c;接入钉钉告警&#xff0c;方便查看 于是使用钩子方法&#xff0c;日志写入完成后&#xff0c;自动调用自定义的告警方法中 1、在application/tags.php 中添加log_write_done > [app\\common\\behavior\\Common, ],2、在…

【THM】Nmap Post Port Scans(后端口扫描)-初级渗透测试

介绍 本房间是 Nmap 系列的最后一个(网络安全简介模块的一部分)。在这个房间中,我们重点关注端口扫描之后的步骤:特别是服务检测、操作系统检测、Nmap脚本引擎和保存扫描结果。 Nmap实时主机发现Nmap基本端口扫描Nmap高级端口扫描Nmap后端口扫描在本系列的第一个房间中,我…

代码随想录第29天|491.递增子序列 46.全排列 47.全排列 II

目录&#xff1a; 491.递增子序列 46.全排列 47.全排列 II 491.递增子序列 491. 非递减子序列 - 力扣&#xff08;LeetCode&#xff09; 代码随想录 (programmercarl.com) 回溯算法精讲&#xff0c;树层去重与树枝去重 | LeetCode&#xff1a;491.递增子序列_哔哩哔哩_bili…

DTFT及其反变换的直观理解

对于离散时间傅里叶变换(DTFT)及其反变换的讲解&#xff0c;教材里通常会先给出DTFT正变换的公式&#xff0c;再举个DTFT的简单变换例子&#xff0c;推导一下DTFT的性质&#xff0c;然后给出DTFT反变换的公式&#xff0c;再证明一下正变换和反变化的对应关系。总的来说就是&…

Spring-IoC 基于xml管理

现大多使用注解方式&#xff0c;xml方式并不简洁&#xff0c;本文仅记录xml用作基础学习。 0、前提 首先在父项目的pom.xml中配置好依赖们。然后子模块也可以使用这些依赖。 在resource目录下创建Spring的xml文件&#xff0c;名称无要求&#xff0c;本文使用bean.xml。文件最…

黄锈水过滤器 卫生热水工业循环水色度水处理器厂家工作原理动画

​ 1&#xff1a;黄锈水处理器介绍 黄锈水处理器是一种专门用于处理“黄锈水”的设备&#xff0c;它采用机电一体化设计&#xff0c;安装方便&#xff0c;操作简单&#xff0c;且运行费用极低。这种处理器主要由数码射频发生器、射频换能器、活性过滤体三部分组成&#xff0c;…

uniapp uni.scss中使用@mixin混入,在文件引入@include 样式不生效 Error: Undefined mixin.(踩坑记录一)

问题&#xff1a; 在uni.scss文件定义mixin 2. 在vue文件引入: 3. 出现报错信息: 4. 问题思考&#xff1a; 是不是需要引入uni.scss &#xff1f; 答案不需要 uni.scss是一个特殊文件&#xff0c;在代码中无需 import 这个文件即可在scss代码中使用这里的样式变量。uni-app的…

原创【matcap材质在ue4中的实现办法】

matcap材质在ue4中的实现办法 2023-08-29 15:34 https://www.bilibili.com/video/BV1GR4y1b76n/?spm_id_from333.337.search-card.all.click&vd_sourced76b773892c830a157c0ccc97ba78411 评论(0)