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

article/2025/9/28 18:13:04

文章目录

  • 一、打印100~200之间的素数
    • 方法一:
      • 1.思路
      • 2.代码如下
      • 3.结果图
    • 方法二:
      • 1.思路
      • 2.代码如下
      • 3.结果图
  • 二、打印乘法口诀表
      • 1.思路
      • 2.代码如下
      • 3.结果图
  • 三、输出1000~2000之间的闰年
      • 1.思路
      • 2.代码如下
      • 3.结果图
  • 四、提升


一、打印100~200之间的素数

素数:素数又叫质数(prime number),有无限个。质数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数。

方法一:

1.思路

  因为素数只能被1和它本身整除,所以我们可以写一个程序,让100到200之间的每一个数都从2开始除,一直除到他的本身减一,如果其中有一个的余数为零,就说明这个数除了本身和1以外,还能被其他数整除,就说明这个数不是素数,不进行打印,反之,则对这个数进行打印。

2.代码如下

#include<stdio.h>
int main()
{int m, i;printf("100~200之间的素数有:\n");for (m = 100; m <= 200; m++){for (i = 2; i <=m-1; i++){if (0 == m % i)break;}if (i >= m)printf("%d ", m);}return 0;
}

3.结果图

如图所示:
运行结果


方法二:

1.思路

  其实仔细思考就可以发现,如果一个数m它不是素数的话,把那些可以整除它的数全部统计起来的话,就会发现这些数是以 m \sqrt m m 为分界线的,所以在我们编写for循环时,终止条件就可以改到 m \sqrt m m ,这样就能更加节省代码运行的时间,使代码更加的高效。

2.代码如下

#include<stdio.h>
#include<math.h>
int main()
{int m, n,i;printf("100~200之间的素数有:\n");for (m = 100; m <= 200; m++){n = (int)sqrt(m);for (i = 2; i <=n; i++){if (0 == m % i)break;}if (i > n)printf("%d ", m);}return 0;
}

3.结果图

如图所示:
运行结果

二、打印乘法口诀表

1.思路

  这个程序就很简单了,只需要两个for循环就能后解决了,一个for循环用来控制行的范围,另一个for循环来控制列的范围,然后对数值进行打印就可以了。

2.代码如下

#include<stdio.h>
int main()
{int m, n;for (m = 1; m < 10; m++){for (n = 1; n <= m; n++){printf("%3d×%d=%2d",n, m, n * m);}printf("\n");}return 0;
}

3.结果图

如图所示:
运行结果

三、输出1000~2000之间的闰年

闰年的判定:1.能被4整除而不能被100整除的为闰年;
      2.或者是能被400整除的闰年。

注:这是一般的判定方法,可能不是那么的准确,更加具体的判断方法请搜索百度。

1.思路

  这个思路就和上面的第一题比较类似了,就是把1000到2000里的每一个数都进行判断,判断其是否符合可以被4整除而不能被100整除,或者是可以被400整除。要对每一个数进行判断可以使用for循环来实现。

2.代码如下

#include<stdio.h>
int main()
{int n;printf("1000~2000之间的闰年有:\n");for (n = 1000; n <= 2000; n++){if ((n % 4 == 0) && (n % 100 != 0) || (n % 400 == 0)){printf("%d ", n);}}return 0;
}

3.结果图

如图所示:
运行结果

四、提升

  有没有感觉这样求固定的东西太死板了,比如我想求100~300之间的素数,我想我可以输入一个范围,它就能打印我想要的结果,这样就能使我的代码更加的高效,更加的人性化,不会那么死板,这样是否可行?
  答案当然是可以的,只需要把那些固定的变量进行一下更改,更改为用scanf()这个函数进行输入,就可以随意更改我们想要的范围了,大家可以试试!然后上面的代码还有一些小的细节,大家可以去理解理解,比如:%3d 这个3的含义是什么 ?等等。


希望这篇文章对大家有所收获,初次编写,请多多包涵。如有雷同,纯属巧合。


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

相关文章

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) 三者的异同 冲突域和广播域 在介绍这三…

交换机基础原理,冲突域和广播域

交换机的基本定义 提供了大量的接入端口&#xff0c;能够很好的满足大量用户接入到网络中的需求。 在OSI模型的二层&#xff0c;数据链路层&#xff1b; 可以识别数据包中的MAC地址信息&#xff0c;根据MAC地址进行转发数据&#xff0c;并且会将这些MAC地址与对应的端口记录在…

冲突域和广播域的区分

一、概念理解&#xff1a; 1、冲突域&#xff08;物理分段&#xff09;&#xff1a; 连接在同一导线上的所有工作站的集合&#xff0c;或者说是同一物理网段上所有节点的集合或以太网上竞争同一带宽的节点集合。这个域代表了冲突在其中发生并传播的区域&#xff0c;这个区域可…

冲突域和广播域的区别

冲突域 冲突域指的是会产生冲突的最小范围&#xff0c;在计算机和计算机通过设备互联时&#xff0c;会建立一条通道&#xff0c;如果这条通道只允许瞬间一个数据报文通过&#xff0c;那么在同时如果有两个或更多的数据报文想从这里通过时就会出现冲突了。 冲突域的大小可以衡…

冲突域和广播域

冲突域&#xff1a; 冲突域是信道的争抢&#xff0c;信道只有一条&#xff0c;A在使用&#xff0c;B就不可以使用&#xff0c;这样就会产生冲突&#xff0c;这就是冲突域的产生 在一个信道上的所有主机组成一个冲突域&#xff0c;划分网络越小越好&#xff0c;不会引起很大的冲…