【C语言】【函数调用】编写函数int fun(int n)打印1-100之间的素数【最基础的一种方法】

目录

1.什么是素数?怎么判断素数?

2.代码及详细注释分析

3.代码(不带注释)

4.运行效果


1.什么是素数?怎么判断素数?

一个数(n)是素数的条件:

  • n >= 2

  • n不能被[2,n)之间的任意的数整除

如 :13 不能被[2,13)之间的任意的数整除,所以13是素数

        15在[2,15)之间,能被3和5整除,所以15不是素数


2.代码及详细注释分析

#include<stdio.h>
int fun(int n) {// m 被传进来了【m的值赋值给了n】 
	int flag = 1;// 定义一个标记【flag = 1 素数 ; flag = 0 不是素数】 
	
	// 如果n <= 1的话肯定不是素数 
	if(n <= 1) flag = 0;
	// 如果n >= 2的话,进行下面的循环 
	for(int i = 2;i < n;i++) {
		if(n % i == 0) {
			// 如果n能被整除,那么n一定不是素数
			flag = 0;
			break;//跳出循环,因为已经断定了n不是素数了,不需要再进行循环了 
		}
		//如果n不能被整除,继续循环
	}
	// 如果循环结束了,n一直不能分别被 [2,n) 之间的数整除,那n就是素数,flag = 1不变 
	return flag;
}

int main( ) {
	int sum = 0;// 定义sum存储素数个数 
	// 判断1-100之间的数是不是素数 
	for(int m = 1;m < 100;m++) {
		// fun(m):把m这个参数传进fun函数,fun函数执行结束后返回flag
		if(fun(m) == 1) {//如果函数返回的值(也就是k) == 1,那么说明m是素数 【其实==1可以不写,直接写if(fun(m))即可,因为0是false,非0是true】 
		// %4d意思是输出最小长度为4,长度不足4时默认前面用空白填补,但超过4时不会截断
			printf("%4d",m);// 输出这个素数 
			sum++;// 素数个数+1 
			if(sum % 5 == 0) { // 当素数个数能被5整除,就换个行 
				printf("\n");
			}
		}
		// 继续循环,判断下一个m是不是素数 
	}
	return 0;
}

3.代码(不带注释)

#include<stdio.h>
int fun(int n) {
	int flag = 1;
	if(n <= 1) flag = 0;
	for(int i = 2;i < n;i++) {
		if(n % i == 0) {
			flag = 0;
			break;
		}
	}
	return flag;
}

int main() {
	int sum = 0;
	for(int m = 1;m < 100;m++) {
		if(fun(m) == 1) {
			printf("%4d",m);
			sum++;
			if(sum % 5 == 0) {
				printf("\n");
			}
		}
	}
	return 0;
}

4.运行效果


如有不足之处欢迎私信或评论~

如果有帮助可以点个赞嘛?谢谢啦~

  • 10
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 可以使用一个函数来判断一个数是否为素数,然后在主程序中循环1-100,对每个数调用该函数进行判断,如果是素数打印出来,并计数。具体代码如下: ```python def is_prime(num): if num < 2: return False for i in range(2, int(num ** .5) + 1): if num % i == : return False return True count = for i in range(1, 101): if is_prime(i): print(i) count += 1 print("1-100之间素数个数为:", count) ``` 运行结果如下: ``` 2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 1-100之间素数个数为: 25 ``` ### 回答2: 素数是指除了1和本身以外,没有其他因子的自然数。在本题中,需要求解1-100之间的所有素数以及其个数,可以使用一个判断一个数是否为素数函数来实现。 判断一个数是否为素数函数可以采用“试除法”,即对于待判断的数n,从2到n-1逐个尝试将n除以每一个数,若都不能被整除,则n是素数,反之则不是素数。具体实现如下: bool is_prime(int n){ if (n <= 1) //小于等于1的数不是素数 return false; for (int i = 2; i < n; i++) { if (n % i == 0) //能被整除则不是素数 return false; } return true; //不能被整除则是素数 } 其中,bool表示返回值为布尔型,若返回true则是素数,反之则不是素数。is_prime函数的输入参数为待判断的数n,需要判断n是否是素数。 接下来,可以使用一个for循环依次遍历1-100中的所有数,对每个数调用is_prime函数进行判断,并将所有素数打印出来统计个数,在代码中可以这么实现: int count = 0; //素数个数 for (int i = 1; i <= 100; i++) { if (is_prime(i)) { //判断i是否为素数 cout << i << " "; //打印素数 count++; //素数个数加1 } } cout << "一共有" << count << "个素数。" << endl; 这样,就可以得到1-100之间的全部素数及其个数了。 ### 回答3: 素数是指只有1和本身两个因数的自然数,如2、3、5、7、11等。我们先定义一个函数is_prime(num),用来判断一个数是否为素数,然后再用循环遍历1-100之间的所有数,判断它们是否为素数,最后将素数输出即可。 具体实现如下: ```python def is_prime(num): if num < 2: return False for i in range(2, int(num ** 0.5) + 1): if num % i == 0: return False return True count = 0 # 记录素数个数 for i in range(1, 101): if is_prime(i): print(i) count += 1 print("1-100之间素数个数为:", count) ``` 解释一下代码的实现过程: 首先定义一个函数is_prime(num),它的作用是判断一个数是否为素数。判断的方法是:如果这个数小于2,则不是素数;如果这个数能够被2~根号下这个数之间的任何一个自然数整除,则不是素数;否则,它就是素数。 然后用一个循环,遍历1-100之间的所有数,对于每一个数,都调用is_prime函数来判断是否为素数。如果是素数,则输出它,并将素数个数加1。最后输出素数个数

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秃头小二

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值