输入一个数,判断是否是素数(一般筛法)

思路:用循环语句一个个试,但只需要试到X的平方根即可(后续等语法和算法提升一下,再试试其他筛法)。

难点:注意设置break跳出循环,避免重复计算。

方法如下:

#include <stdio.h>
#include <math.h>

int main() {
	int n;
	int x;
	int prime = 1;//定义prime,如果未进入循环一次,则直接为素数

	printf("请输入要判断的数字\n");
	scanf("%d", &x);
	//从2开始逐个试
	for (n = 2; n < sqrt(x); n++) {
		if (x % n == 0) {//如果余数为0,表示除得尽
			prime = 0;//那么重新定义prime为0
			break;//第一次得出结果后,直接跳出循环
		}
	}
	if (prime == 1) {
		printf("是素数\n", x);
	} else {
		printf("不是素数\n", x);//prime=0则为和数
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值