【C语言】C语言入门经典题目(范围广,内容多)

article/2025/9/28 18:11:32

✨作者:@小孙的代码分享

✨专栏:《C语言入门》

✨送给各位的一句话:空杯心态 才能学到新知

✨希望大家看完这些题目有所收获,别忘了,点赞+评论!

目录

前言 😄

字符转ASCII码🔥

判断闰年🔥

 简单计算器🔥

 包含数字9的数🔥

十六进制转十进制🔥

 获得月份天数🔥

 求质数个数🔥

 水仙花数🔥

变种水仙花🔥

 公务员面试🔥

 关机程序🔥

结束语


前言 😄

学了好久的C语言,最近也刷了200多到题,下面和大家分享一下我直接的一些入门的经典题目,还望大佬指正,如果大家觉得好,也记得留下点赞和收藏奥。


字符转ASCII码🔥

题目很清楚,就是输入一个字符。输出输入字符对应的ASCII码。示例代码如下

#include<stdio.h>
int main()
{char c;scanf("%c",&c);printf("%d",c);return 0;
}

 实现:


 

判断闰年🔥

输入一个整数n ,判断一个整数n是否是闰年,是闰年输出"yes" 否则输出"no"。下面我带大家来了解一下闰年:

 普通闰年:a%4==0 && a%100!=0

 世纪闰年:a%400==0

示例代码如下:

#include<stdio.h>
int main()
{int a;scanf("%d",&a);if((a%4==0 && a%100!=0)||a%400==0){printf("yes\n");}elseprintf("no\n");return 0;
}

 结果如图:


 

 简单计算器🔥

实现输入一行字符串操作数1+运算符+操作数2 (其中合法的运算符包括:+、-、*、/)。如果操作数和运算符号均合法,则输出一个表达式,操作数1运算符操作数2=运算结果,各数小数点后均保留4位,数和符号之间没有空格。如果输入的运算符号不包括在(+、-、*、/)范围内,输出“Invalid operation!”。当运算符为除法运算,即“/”时。如果操作数2等于0.0,则输出“Wrong!Division by zero!”。

示例代码如下:

#include<stdio.h>
int main()
{double a,b;char c;scanf("%lf %c %lf",&a,&c,&b);if(c=='+'){printf("%.4f%c%.4f=%.4f",a,c,b,a+b);}else if(c=='-'){printf("%.4f%c%.4f=%.4f",a,c,b,a-b);}else if(c=='*'){printf("%.4f%c%.4f=%.4f",a,c,b,a*b);}else if(c=='/'){if(b==0.0){printf("Wrong!Division by zero!\n");}else{printf("%.4f%c%.4f=%.4f",a,c,b,a/b);}}else{printf("Invalid operation!\n");}return 0;
}

结果如图:

 


 

 包含数字9的数🔥

由题目可以看出,计算数字中包含9的数字个数9,先给定一个范围吧0-2019之间数字中包含9的数的个数,进行循环统计出来。(个位,十位,百位中只要至少有一位含有9就是我们要的数字),示例代码如下:

#include<stdio.h>int main()
{int i = 0, count = 0;for (i = 1; i <= 2019; i++){if (i%10 == 9 || i/10%10 == 9 || i/100% 10 == 9){count++;}}printf("%d", count);return 0;
}

结果如图:

 

由此可知0-2019之间含有9的数字有544个。


 

十六进制转十进制🔥

 比如写了一个十六进制整数ABCDEF,问你对应的十进制整数是多少。

小tips:十六进制整数ABCDEF对应的十进制整数,所占域宽为15。

#include<stdio.h>
int main()
{int n=0XABCDEF;printf("%15d\n",n);return 0;
}

结果如图:

 


 

 获得月份天数🔥

就是多组输入,一行有两个整数,分别表示年份和月份,用空格分隔。针对每组输入,输出为一行,一个整数,表示这一年这个月有多少天。其实不难,就是先判断是几月份,如果是2月份就要判断是否为闰年。

示例代码如下:

#include<stdio.h>
int main()
{int y,m;while(scanf("%d %d",&y,&m)!=EOF){switch(m){case 1:case 3:case 5:case 7:case 8:case 10:case 12:printf("31\n");break;case 4:case 6:case 9:case 11:printf("30\n");break;case 2:if(y%400==0||(y%4==0&&y%100!=0))printf("29\n");else printf("28\n");break;}} return 0;
}

结果如图:

 


 

 求质数个数🔥

设计程序输出三位数中,质数的个数。顾名思义三位数就是100-1000之间,质数就是只有1和它本身可以整除自己。下面我们来看看代码:

#include <stdio.h>
int main()
{int n, i, cnt=0;for (n=100; n<1000; n++){int flag =1;   //学会用flag,当只要有一个个例出现就可以确定的判断时for(i=2; i<n; i++)   //对从2到n-1的数取余{ if(n % i == 0)  //只要有一个取余=0,表示可以整除,不是质数flag = 0;   //易帜}if(flag == 1)  //内循环结束时全都没有易帜,表示全都不能整除,是质数cnt++;}printf("%d\n", cnt);return 0;
}

结果如下:

 

得到100-1000中质数的个数为143.


 

 水仙花数🔥

春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的: “水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。 现在要求输出所有在m和n范围内的水仙花数。

代码如下:

#include<stdio.h>
int e = 0;
int sx(int a, int b)
{int sum = 0;for (; a <= b; a++){sum = (a / 100) * (a / 100) * (a / 100) + (a % 100 / 10) * (a % 100 / 10) * (a % 100 / 10) + (a % 10) * (a % 10) * (a % 10);if (sum == a){printf("%d ", a);e++;}}return e;
}int main()
{int a, b;int sum = 0;int f = 0;while ((scanf("%d %d", &a, &b)) != EOF){sx(a, b);if (e == 0){printf("no");}printf("\n");}return 0;
}

 结果如下:


 

变种水仙花🔥

上面刚了解完水仙花数,带大家认识认识变种水仙花数。

变种水仙花数 - Lily Number:把任意的数字,从中间拆分成两个数字,比如1461 可以拆分成(1和461),(14和61),(146和1),如果所有拆分后的乘积之和等于自身,则是一个Lily Number。

例如:

655 = 6 * 55 + 65 * 5

1461 = 1*461 + 14*61 + 146*1

求出 5位数中的所有 Lily Number。

代码如下:

#include<stdio.h>
int main()
{int i;int j;for(i=10000;i<100000;i++){int sum=0;for(j=10;j<=10000;j=10*j){sum+=(i/j)*(i%j);}if(sum==i)printf("%d ",i);}return 0;
}

结果如图:

 


 

 公务员面试🔥

公务员面试现场打分。有7位考官,从键盘输入若干组成绩,每组7个分数(百分制),去掉一个最高分和一个最低分,输出每组的平均成绩。

题目通俗易懂,直接上代码:

#include <stdio.h>
int main()
{int a, max = 0, small = 100, sum = 0, count = 0;while (scanf("%d", &a) != EOF){   //把最大最小值找出拿出来if (a > max){max = a;}if (a < small){small = a;}//求和sum += a;count++;if (count == 7)//计数器=7时代表一组的分数好了可以进行计算{printf("%.2f\n", (sum - max - small) / 5.0);count = 0;max = 0;small = 100;sum = 0;}	}return 0;
}

结果如图:

 


 

 关机程序🔥

在今天的最后给大家一个恶搞的关机程序,关机程序就是利用分支循环中goto实现,这里再来看一遍我们的代码:

上代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{char input[20] = { 0 };system("shutdown - s - t 60");
again:printf("请注意,你的电脑将在一分钟后关机,如果输入:'对不起',就取消关机\n");scanf("%s", input);if (strcmp(input, "对不起") == 0){system("shutdown -a");}else{goto again;}return 0;
}

效果演示,大家可以去恶搞室友了。

 

 

 


 

结束语

今天的分享就先到这里,如果感觉有用就留下点赞,博主会定期更新一些题目,大家一起学习,

 


http://chatgpt.dhexx.cn/article/X4P3wr9p.shtml

相关文章

C语言入门1:Hello World

C语言入门1&#xff1a;Hello World 1、第一个C语言程序&#xff1a;Hello World&#xff01;&#xff08;1&#xff09;编辑hello.c文件&#xff08;2&#xff09;在hello.c下面编辑如下代码&#xff0c;并保存&#xff08;3&#xff09;编译hello.c文件&#xff08;4&#xf…

C语言入门(1)——Hello World

C语言入门(1)——Hello World 1. 第一个C语言程序&#xff1a;Hello World 开始的第一个程序是一个最简单的程序&#xff0c;也就是最经典的Hello World程序&#xff0c;它的功能为打印出Hello World。程序的内容非常简单&#xff0c;也是C语言编写程序的基本结构框架。 1.示…

c语言入门介绍 Hello, World

相信每一个c语言的初学者的第一个程序都是从 Hello, World! 开始的吧。不过新手刚开始接触&#xff0c;应该有许多不懂的地方&#xff0c;下面我就通过Visual Studio 2019编程环境来简单介绍一下这个程序。 第一句是由于Visual Studio 2019编程环境中scanf函数&#xff08;输入…

C语言入门的三个简易程序

文章目录 一、打印100&#xff5e;200之间的素数方法一&#xff1a;1.思路2.代码如下3.结果图 方法二:1.思路2.代码如下3.结果图 二、打印乘法口诀表1.思路2.代码如下3.结果图 三、输出1000&#xff5e;2000之间的闰年1.思路2.代码如下3.结果图 四、提升 一、打印100&#xff5…

C语言入门 九九乘法表

利用C语言 输出九九乘法表 用双重循环来完成&#xff0c;外循环用变量i控制输出的行数&#xff08;总共九行&#xff09;同时i也是被乘数。 内循环用变量j循还控制列号&#xff0c;同时j也是乘数&#xff0c;规定列号不能大于行号&#xff0c;每一行输出结束后换行。 #inclu…

C语言入门之入门

错误示范 #include<stdio.h> //头文件int mian(void){printf("你好世界&#xff01;"); //标准输出函数&#xff0c;是一个库函数return 0;}上面这个程序是有问题的&#xff0c;第一次写的时候没有运行成功 编译环境是 Visual C2010 查找之后发现是main 写…

C语言入门(初识C语言)

C语言入门&#xff08;初识C语言&#xff09; 前言什么是C语言&#xff1f;为什么选择C语言&#xff1f;计算机语言的发展高级计算机语言中的经典&#xff1a;C语言 初识C语言&#xff08;正片开始&#xff09;一.第一个C语言程序&#xff08;你好&#xff0c;C语言&#xff09…

网络流(一)最大流问题EdmondsKarp和最小费用最大流

一、最大流问题 如下图所示&#xff0c;假设需要把一些物品从结点S&#xff08;称为源点&#xff09;运送到结点t&#xff08;称为汇点&#xff09;&#xff0c;可以从其它结点中转。每条边上的权值&#xff08;左图&#xff09;表示该条路径最多能运送的物品数&#xff0c;右…

最大流,最小费用最大流:解析 + 各种板子

网络流初步 Edmond-Karp算法 网络流的基本概念 源点&#xff0c;这个点只有流量的流出&#xff0c;没有流入。汇点&#xff0c;这个点只有流量的流入&#xff0c;没有流出。容量&#xff0c;每条有向边的最大可承受的流的理论大小。流量&#xff0c;每条有向边的最大可承受的…

分配问题(最小费用最大流)

题目&#xff1a;有 n 件工作要分配给 n 个人做。第 i个人做第 j件工作产生的效益为 。试设计一个将 n件工作分配给 n个人做的分配方案&#xff0c;使产生的总效益最大。 分析&#xff1a;这是一道多解法问题&#xff0c;可以用带剪枝的搜索和图论的最小费用最大流的方法来做&…

最小费用最大流算法 网络流

最小费用最大流算法 图片来源 《趣学算法》 人民邮电出版社 陈小玉 代码实现 /* 参考:《趣学算法》陈小玉 人民邮电出版社 最小费用最大流---最小费用路算法 问题分析:在实际应用中&#xff0c;要同时考虑流量和费用&#xff0c;每条边除了给定容量之外&#xff0c;还定义了一…

网络流----最小费用最大流(EK+SPFA)

先来介绍一下什么是费用流&#xff08;部分内容参考bilibili董晓算法&#xff09; 给定一个网络G&#xff08;V&#xff0c;E&#xff09;&#xff0c;每条边有容量限制w(u,v)&#xff0c;还有单位流量的费用c(u,v)。 当&#xff08;u,v&#xff09;的流量为f(u,v)时&#xf…

【图论】网络流——最大流和最小费用流

【图论】网络流——最大流和最小费用流 文章目录 【图论】网络流——最大流和最小费用流1. 最大流问题1.1 基本概念1.2 寻求最大流的算法&#xff08;Ford-Fulerson&#xff09;1.3 matlab求最大流 2. 最小流问题2.1 基本概念2.2 求最小流的迭代算法2.3 matlab 求最大费用最小流…

网络流(2)-----最小费用最大流(附带讲解SPFA算法)

一.最小费用最大流&#xff08;简称费用流&#xff09;概念 1.什么是费用流问题 上篇文章我们讲解了最大流问题&#xff0c;那什么是最小费用最大流呢&#xff1f;听名字就可以看出&#xff0c;我们要在满足最大流的同时找到达成最大流的最小费用。对于一个网络流&#xff0c…

最小费用最大流问题详解

最小费用最大流问题 一、问题描述 在网络中求一个最大流f&#xff0c;使流的总输送费用最小。 b ( f ) ∑ ( v i , v j ) b i j f i j b(f) \sum\limits_{(v_i,v_j)} b_{ij} f_{ij} b(f)(vi​,vj​)∑​bij​fij​ ) &#xff08; b i j b_{ij} bij​ 表示弧 ( v i , v j…

最小费用最大流问题与算法实现(Bellman-Ford、SPFA、Dijkstra)

摘要 今日&#xff0c;对最小费用最大流问题进行了一个简单的研究&#xff0c;并针对网上的一些已有算法进行了查找和研究。博客和资料很多&#xff0c;但是留下的算法很多运行失败、出错&#xff0c;或者意义不明。这里&#xff0c;个人对其中的Bellman-Ford、SPFA、改进的Di…

如何区分冲突域和广播域?

举个例子&#xff0c;原始社会的人都生活在山洞里&#xff0c;每个人都住在自己的山洞里&#xff0c;洞穴的中间只有一个狭长的走廊可以出去&#xff0c;平时出去玩&#xff0c;大哥都会喊一嗓子&#xff0c;有人出去打猎不&#xff0c;所有人都听得到&#xff0c;这就是一个广…

冲突域和广播域区别

一、区别 1、广播域就是说如果站点发出一个广播信号后能接收到这个信号的范围。通常来说一个局域网就是一个广播域。冲突域指一个站点向另一个站点发出信号。除目的站点外&#xff0c;有多少站点能收到这个信号。这些站点就构成一个冲突域。 2、冲突域通过集线器连接&#xf…

冲突域和广播域区别,集线器、交换机和路由器对比

冲突域 我们把以太网想象为对讲机&#xff0c;电脑想象为使用对讲机的人&#xff0c;数据传输想象为使用对讲机说话。现在一群人打真人CS&#xff0c;两个及以上的人同时通过对讲机说话&#xff0c;就听不清在说什么了&#xff0c;这就是冲突。对讲机通道只能一人单独使用。对…

冲突域和广播域; 集线器、交换机以及路由器比较

转自https://blog.csdn.net/gui951753/article/details/79402528#1%E5%B7%A5%E4%BD%9C%E5%B1%82%E6%AC%A1%E4%B8%8D%E5%90%8C 目录 冲突域和广播域 联网中继设备 集线器&#xff08;hub&#xff09; 交换机(switch) 路由器(route) 三者的异同 冲突域和广播域 在介绍这三…