C语言常见题目 过关斩将(1)C语言的那些坑题,你可知道❓

我的个人主页☆光之梦☆的博客_CSDN博客-C语言基础语法(超详细)领域博主

欢迎各位 👍点赞 ⭐收藏 📝评论

我的专栏C语言基础语法(超详细)_☆光之梦☆的博客-CSDN博客(这个专栏里的平均文章质量分是95噢,基本全都是高质量文章,本博主将会长期更新c语言的语法知识,初学c语言的朋友们,可以收藏订阅一下,收藏绝对不亏噢)

目录

一、交换两个变量的值

二、C语言细节考察题(坑题❗)

坑货(1)❗❗❗

坑货(2)❗❗❗

三、逆序的三位数(难题)

四、两个数比较大小(常考)

【方案1】

【方案2】

 五、计算阶乘

【方案1】

【方案2】 

六、计算平均数

七、猜数游戏(经典)

八、数的逆序输出(本文最难)

需要掌握的知识点

方案1(700——7, 007——7)  

方案2(700——007)  

九、学习路上遇到的常见错误(坑❗)


一、交换两个变量的值

核心代码:

t = a;
a = b;
b = t;

#include <stdio.h>int main()
{int a = 5;int b = 6;//新建第三方变量 int t;printf("原来:a = %d,b = %d\n",a,b);//交换两个变量的值 t = a;a = b;b = t;printf("现在:a = %d,b = %d\n",a,b);return 0;
}

二、C语言细节考察题(坑题❗)

注:前方有坑,不要见坑就跳噢

坑货(1)❗❗❗

写出以下代码执行后,t1和t2的值,以空格隔开:

int a=14;

int t1 = a++;

int t2 = ++a;

怎么样?算完了吗?你应该没有跳进这个坑吧(希望你没跳进去,如果掉坑了,肯定就是你算的太快了)?

来吧,接下来

让我们揭晓答案

答案:14 16

答案解析:

正如我们所知,a一开始的值是14

执行完第一个表达式:int t1 = a++;                这时 t1的值是14

相信这一步,大家应该都知道(这么简单,你当我是三岁小孩啊)

但接下来,才是重头戏(毕竟主角往往是最后出场的嘛)

这里注意哦 这时a的值是15,不是14噢

接着我们执行第二个表达式:int t2 = ++a

这时 t2 的值是 16        a的值也是16

坑在哪呢?如果我们在执行完第一条语句 int t1 = a++; 

把a 和t1 一样当成 14

这样我们就很容易把 t2 算成 15

就容易出错啦(不过这个坑比较小,如果你细心一点,你慢一点,不要算太快就不太会掉坑)

所以正确的答案是:14 16

坑货(2)❗❗❗

写出以下表达式的结果,结果之间间隔一个空格:

6 + 5 / 4 - 2  

2 + 2 * (2 * 2 - 2) % 2 / 3  

10 + 9 * ((8 + 7) % 6) + 5 * 4 % 3 * 2 + 3 

1 + 2 + (3 + 4) * ((5 * 6 % 7 / 8) - 9) * 10

小提示:先括号,再从左到右乘除,最后加减

不要看这道题觉得很简单,就大意噢

轻敌的话,它可是会让你后悔的❗

答案:5 2 44 -627

答案解析:

这道题做错了,一看就是你轻敌了,大意了吧

做太快了吧,不好好检查一遍就交卷吧

6 + 5 / 4 - 2                               从左到右                       7 - 2

2 + 2 * (2 * 2 - 2) % 2 / 3          先括号     2+2*2%2/3  再从左到右       2+0/3         2

10 + 9 * ((8 + 7) % 6) + 5 * 4 % 3 * 2 + 3                       10 + 27 + 4 + 3

1 + 2 + (3 + 4) * ((5 * 6 % 7 / 8) - 9) * 10    3 + 7 * (2/8-9)* 10    3 + 7 * (0-9)* 10         3-630

三、逆序的三位数(难题)

逆序的三位数

程序每次读入一个正三位数,然后输出逆序的数字。注意,当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入700,输出应该是7

提示:用%10可以得到个位数,用/100可以得到百位数...。将这样得到的三个数字合起来:百位100+十位10+个位,就得到了结果。

代码示例:

#include <stdio.h>int main()
{int a;int ge,shi,bai;printf("请输入一个三位数:");scanf("%d",&a);ge = a %10;shi = a % 100 / 10;bai = a / 100;//printf("ge=%d,shi=%d,bai=%d\n",ge,shi,bai);printf("%d\n",ge*100+shi*10+bai);return 0;
}

注:

关系运算符的结果只有0和1

所有的关系运算符的优先级比算术运算的低,但是比赋值运算的高

四、两个数比较大小(常考)

【方案1】

#include <stdio.h>int main(){// 方案1 int a,b;printf("请输入两个整数:");scanf("%d %d",&a,&b);int max = b;if(a > b){max = a;}printf("大的那个是%d\n",max);return 0;
}

【方案2】

#include <stdio.h>int main(){// 方案2int a,b;printf("请输入两个整数:");scanf("%d %d",&a,&b);int max = 0;if (a > b){max = a;} else {max = b;}printf("大的那个是%d\n",max);return 0;
}

 tips:

测试数据(测试所编写的代码或者方法有没有问题)

测试程序常使用边界数据,如

  • 有效范围两端的数据

  • 特殊的倍数等个位数;

  • 10

  • 0

  • 负数

 五、计算阶乘

n!=1×2×3×4×..×n 写一个程序,让用户输入,然后计算输出 n!

变量:

显然读用户的输入需要一个 int 的 n,然后计算的结果需要用一个变量保存,可以是 int 的 factor,在计算中需要有一个变量不断地从 I 递增到 n,那可以是 int 的 

【方案1】

#include <stdio.h>int main()
{int n;scanf("%d",&n);int fact = 1;int i = 1;while(i <= n){fact *= i;i++;}printf("%d!=%d\n",n,fact);return 0;
}

【方案2】 

#include <stdio.h>int main()
{int n;scanf("%d",&n);int fact = 1;int i = 1;for(i = 1; i <= n; i++){fact *= i;}printf("%d!=%d\n",n,fact);return 0;
}

算法小套路

做求和的程序时,记录结果的变量应该初始化为 0,而做求积的变量时,记录结果的变量应该初始化为

六、计算平均数

需求:让用户输入一系列的正整数,最后输入-1表示输入结束,然后程序计算出这些数字的平均数,输出输入的数字的个数和平均数

实现思路:

只需要每读到一个数,就把它加到一个累加的变量里,到全部数据读完,再拿它去除读到的数的个数就可以了

一个变量记录累加的结果,一个变量记录读到的数的个数

算法

  1. 初始化变量 sum 和 count 为 0;

  2. 读入 number;

  3. 如果 number 不是 -l,则将 number 加入 sum,并将 count.加 l,回到2;

  4. 如果 number 是 -l,则计算和打印出 sum/count (注意换成浮点来计算)

代码实现:

#include <stdio.h>int main()
{int number;int sum = 0;//求和 int count = 0;//统计输入的个数printf("请输入要计算平均数的数:");scanf("%d",&number);while(number != -1){sum += number;count++;scanf("%d",&number);}printf("%f\n",1.0*sum/count);//将结果转化成浮点数 return 0;
}

七、猜数游戏(经典)

猜数游戏

需求:让计算机来想一个数,然后让用户来猜用户每输入一个数,就告诉它是大了还是小了,直到用户猜中为止,最后还要告诉用户它猜了多少次。 因为需要不断重复让用户猜,所以需要用到循环

核心重点是循环的条件

人们往往会考虑循环终止的条件

步骤

  1. 计算机随机想一个数,记在变量 number 里;

  2. 一个负责计次数的变量 count 初始化为 0;

  3. 让用户输入一个数字 a;

  4. counti 递增(加一);

  5. 判断 a 和 number 的大小关系,如果 a 大,就输出“大”;如果 a 小就输出“小”;

  6. 如果 a 和 number:是不相等的(无论大还是小),程序转回到第 3 步;

  7. 否则,程序输出“猜中”和次数,然后结束。

需要掌握的知识点

随机数 每次召唤 rand( ) 就得到一个随机的整数

随机产生一个100以内的数:rand( )%10

注:玩这个小游戏,只要你认真玩,那么最多你猜7次就能猜中 

代码实现:

#include <stdio.h>int main()
{srand(time(0));int number = rand()%100;//生成一个100以内的随机数int count = 0;//统计猜数的次数 int a = 0;//用户输入的数printf("我已经想好了一个1到100之间的数。");do{printf("请猜猜这个1到100之间的数:");scanf("%d",&a);count++;if (a > number){printf("你猜的数大了。");} else if (a < number){printf("你猜的数小了。");}} while(a != number);printf("太好了,你用了%d次就猜到了答案。\n",count);return 0;
}

 为什么100以内的数猜7次就够了?

2的7次方为128,使用二分法完全可以取到100内的任意整数

用二分法,例如第一次:100中猜50第二次:若大了,1~50中猜25第三次:若小了,26~50中猜38第四次:若小了,39~50中猜45第五次:若大了,39~45中猜42第六次:若大了,39~41中猜40第七次:若大了就是39,若小了就是41。

八、数的逆序输出(本文最难)

输入一个正整数,输出逆序的数

如:

【情况1】

输入:700        输出:7

输入:007        输出:7

【情况2】

输入:700        输出:007

注:想做出这题需要先掌握下列知识(否则就是鸡蛋碰石头哦)

需要掌握的知识点

整数的分解

整数的分解 一个整数是由 1 至多位数字组成的,如何分解出整数的各个位上的数字,然后加以计算

  • 对一个整数做%10 的操作,就得到它的个位数;

  • 对一个整数做/10 的操作,就去掉了它的个位数;

  • 依此类推。

当 x > n 时

1234 % 10                保留末尾一位数 4

1234 % 100              保留末尾二位数 34

1234 / 10                  去掉末尾一位数 123

1234 / 100                去掉末尾二位数 12

当 x < n

1 % 10 1                 小取余大 余小本身

5 % 10 5                 小取余大 余小本身

6 % 10 6                 小取余大 余小本身

1 / 10 0                 被除数比除数小 答案为0

5 / 10 0                 被除数比除数小 答案为0

6 / 10 0                 被除数比除数小 答案为0

方案1(700——7, 007——7)  

代码示例:

#include <stdio.h>int main()
{//用户要输入的数 int x;x = 12345;//007	7		700		7 //定义一个变量用来保存依次取出的数int digit;//定义一个变量用来保存逆序输出的结果int ret = 0;while(x > 0){//依次取出最后一位数 digit = x % 10;//原来的结果往左移动一位加上新的digit ret = ret * 10 + digit;printf("x=%d,digit=%d,ret=%d\n",x,digit,ret);//x去除一位 x /= 10; }printf("%d",ret);return 0;
}

方案2(700——007)  

代码示例:

#include <stdio.h>int main()
{//用户要输入的数 int x;//scanf("%d",&x);x = 700;//007//定义一个变量用来保存依次取出的数int digit;//定义一个变量用来保存逆序输出的结果int ret = 0;while(x > 0){//依次取出最后一位数 digit = x % 10;printf("%d",digit);//原来的结果往左移动一位加上新的digit ret = ret * 10 + digit;//x去除一位 x /= 10; }return 0;
}

九、学习路上遇到的常见错误(坑❗)

(1)if 语句 忘了大括号

解决方法:永远在 if 和 else 后面加上大括号,即使当时后面只有一条语

(2)在 if 后面加分号

(3)错误使用==和=

(4)输入中文符号

(5)scanf()里面忘记加&

(6);老丢

(7)scanf()里面忘记加& printf()里面加了&

各位学习C语言的初学者,如果有问题随时都可以来问我,我会随时为您解答!欢迎大家与我一起学习,互相进步。

创作不易,👍 +⭐ +📝(一键三连) 是对博主最大的鼓励与支持哦。

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

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

相关文章

学网络安全的过程 ,差点要了我的命

我真的好像感慨一下&#xff0c;这个世界真的给计算机应届生留活路了吗&#xff1f; 看着周围的同学&#xff0c;打算搞前端、JAVA、C、C的&#xff0c;一个两个去跑去应聘。你以为是00后整治职场&#xff1f; 真相是主打一个卑微&#xff1a;现阶段以学习为主&#xff08;工资…

保护互联网数据安全:关键方法与最佳实践

在当今数字化时代&#xff0c;互联网数据安全已经成为个人、企业和组织的首要任务之一。随着信息技术的迅猛发展&#xff0c;网络威胁也不断演进&#xff0c;因此保护互联网数据安全变得尤为关键。本文将介绍一些关键方法和最佳实践&#xff0c;帮助您确保互联网数据的安全性。…

input时间控件选择时禁用某个日期之前或之后

【版权所有&#xff0c;文章允许转载&#xff0c;但须以链接方式注明源地址&#xff0c;否则追究法律责任】【创作不易&#xff0c;点个赞就是对我最大的支持】 前言 仅作为学习笔记&#xff0c;供大家参考 总结的不错的话&#xff0c;记得点赞收藏关注哦&#xff01; 目录 …

微服务09-Sentinel的入门

文章目录 微服务中的雪崩现象解决办法&#xff1a;1. 超时处理2. 舱壁模式3. 熔断降级4.流量控制 Sentinel1.介绍2.使用操作3.限流规则4.实战&#xff1a;流量监控5.高级选项功能的使用1.关联模式2.链路模式3.总结 流控效果1.预热模式2.排队等待模式3.总结4.热点参数限流5.实战…

东芝Z750的画质真实吗?适合看纪录片吗?

东芝Z750显示的画面更加真实、细腻、有层次感,就感觉电视中的画面像真实世界一般呈现在眼前,东芝电视拥有70余年的原色调校技术,每款产品都有专属的日本调校工程师匠心打造,可以真实还原画面色彩,若是观看类似《航拍中国》这样的旅游记录片时,东芝电视将会营造出万里山河的壮阔…

OpenCV3-Python(7)模板匹配和霍夫检测

模板匹配 膜版匹配不能匹配尺度变换和视角变换的图像 图片中查找和模板相似度最高的图像 计算相似程度最高的位置 res cv.matchTemplate(img , template, method) 该方法返回一个类似灰度图的东西&#xff0c;如果用的相关匹配&#xff0c;那么亮的地方就是可能匹配上的地方 …

Svelte生命周期(加整体概述)

目录 前言 一、编译阶段 1. 导入语句 2. 组件声明 3. 模板部分 4. CSS样式 二、运行时阶段 三、生命周期函数 1. onMount 2. beforeUpdate 与 afterUpdate 3. onDestroy 4. setContext 与 getContext 6. hasContext 7. getAllContexts 前言 Svelte是一种现代的Ja…

聚观早报 | 首个“5G-A智慧家庭”发布;李鹏称5G-A是5G发展选择

【聚观365】10月12日消息 首个“5G-A智慧家庭”发布 李鹏称5G-A是5G发展的自然选择 新版努比亚Z50S Pro开售 英特尔锐炫A580显卡全球同步上市 vivo X100系列年底登场 首个“5G-A智慧家庭”发布 在全球移动宽带论坛&#xff08;MBBF2023&#xff09;期间&#xff0c;du联合…

04_学习springdoc与oauth结合_简述

文章目录 1 前言2 基本结构3 需要做的配置 简述4 需要做的配置 详述4.1 backend-api-gateway 的配置4.1.1 application.yml 4.2 backend-film 的配置4.2.1 pom.xml 引入依赖4.2.2 application.yml 的配置4.2.3 Spring Security 资源服务器的配置类 MyResourceServerConfig4.2.4…

vue打印功能

安装 vue3-print-nb yarn add vue3-print-nb //或 npm install vue3-print-nbmain.js中引入 vue3-print-nb import { createApp } from vue; import App from ./App.vue; const app createApp(App); // 打印插件 import print from vue3-print-nb app.use(print) //页面内引…

Webapck 解决:[webpack-cli] Error: Cannot find module ‘vue-loader/lib/plugin‘ 的问题

1、问题描述&#xff1a; 其一、报错为&#xff1a; [webpack-cli] Error: Cannot find module vue-loader/lib/plugin 中文为&#xff1a; [webpack-cli] 错误&#xff1a;找不到模块“vue-loader/lib/plugin” 其二、问题描述为&#xff1a; 在项目打包的时候 npm run …

c++视觉图像----扩充边界

图像扩充边界 #include <opencv2/opencv.hpp> #include <opencv2/highgui/highgui.hpp>int main() {// 读取图像cv::Mat image cv::imread("1.jpg", cv::IMREAD_COLOR);if (image.empty()) {std::cerr << "Could not open or find the imag…

Java项目调用Python脚本(基于idea)

前期准备 1.首先需要在本地环境中安装配置python环境 Python(含PyCharm及配置)下载安装以及简单使用(Idea) 博主本次使用python版本为py3.7.3 2.idea安装python插件 位置&#xff1a;File->Settings->Plugins->python->安装后重启即可 3.引入jython依赖 &l…

力扣 -- 1312. 让字符串成为回文串的最少插入次数

解题步骤&#xff1a; 参考代码&#xff1a; class Solution { public:int minInsertions(string s) {int ns.size();vector<vector<int>> dp(n,vector<int>(n));//无需初始化//填表for(int in-1;i>0;i--){for(int ji;j<n;j){//状态转移方程if(s[i]s[…

如何在 Spring Boot 中进行数据备份

在Spring Boot中进行数据备份 数据备份是确保数据安全性和可恢复性的关键任务之一。Spring Boot提供了多种方法来执行数据备份&#xff0c;无论是定期备份数据库&#xff0c;还是将数据导出到外部存储。本文将介绍在Spring Boot应用程序中进行数据备份的不同方法。 方法1: 使用…

【深度学习实验】循环神经网络(一):循环神经网络(RNN)模型的实现与梯度裁剪

目录 一、实验介绍 二、实验环境 1. 配置虚拟环境 2. 库版本介绍 三、实验内容 0. 导入必要的工具包 1. 数据处理 2. rnn 测试 3. grad_clipping 4. 代码整合 经验是智慧之父&#xff0c;记忆是智慧之母。 ——谚语 一、实验介绍 本实验介绍了一个简单的循环神经网络…

如何优化前端图像和多媒体资源?

聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发…

电子书制作软件Vellum mac中文版特点

Vellum mac是一款专业的电子书制作软件&#xff0c;它可以帮助用户将文本文件转换为高质量的电子书&#xff0c;支持多种格式&#xff0c;包括EPUB、MOBI、PDF等。Vellum具有直观的用户界面和易于使用的工具&#xff0c;可以让用户快速地创建和发布电子书。 Vellum mac软件特点…

与艺术同频!卡萨帝在海外崭露头角

在品牌全球化步伐日益加快的当下&#xff0c;高端品牌如何真正实现业务全球化、品牌全球化乃至用户圈层全球化&#xff1f; 作为国际高端家电引领者&#xff0c;卡萨帝今年以来在全球范围内展开了一系列的品牌布局活动。1月&#xff0c;卡萨帝于巴基斯坦召开品牌发布会&#x…

分类预测 | MATLAB实现基于RF-Adaboost随机森林结合AdaBoost多输入分类预测

分类预测 | MATLAB实现基于RF-Adaboost随机森林结合AdaBoost多输入分类预测 目录 分类预测 | MATLAB实现基于RF-Adaboost随机森林结合AdaBoost多输入分类预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.MATLAB实现基于RF-Adaboost随机森林结合AdaBoost多输…