实现求1-n之间的素数并打印

☆樱花仙子☆ 提交于 2020-01-13 05:12:03

代码

#include <stdio.h>
int main(void) {
	   	//求1-n之间素数并打印
		int n,k = 0,count = 1;//count用于计数,因为2是直接输出没有判断的,所以count初始化为1.
		printf("请输入一个整数n,用于求1-n之间的素数: ");
		scanf_s("%d", &n);
		printf("2 ");//2就不判断了,直接输出.
		for (int j = 2; j <= n; j++){//从2到n循环一边,看哪些数字符合下面的条件
			for (int i = 2; i < j ; i++) {//i是除了1和他本身之间的整数
				if (j % i == 0)//满足这个条件说明j可以整除i,所以j不是素数,则使用break跳出循环.
					break;
				else if ((j % i != 0) && (i == (j-1)))//满足此条件说明已经验证到最后一个因子,将它的值赋给k
					k = j;
				else//这个就是j不整除i,而且还没有验证到最后一个数字,则进入下一轮循环
					continue;
				count++;
				printf("%d ", k);
			}				
		}
		printf("\n1-%d有%d个素数", n, count);
	return 0;
}
 

结果如下图所示:

求1-100之间的素数
在这里插入图片描述

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!