C语言编程之素数的判定

给出一个大于或等于3的正整数,判定它是不是一个素数。

解题思路:所谓素数是指:除了1和该数本身之外,不能被其他任何整数整除的数。n不必被2–n-1的整数除,只需被2–n/2间整数除即可,甚至只需被2–√2之间的整数除即可。

代码:

#include"stdio.h"
int main() { 
	int a, i;
	do {
		printf("input number judge primenumber:\n");
		scanf("%d", &a);
		for (i = 2; i < a; i++)
			if (a%i == 0)break;
		if (i == a)
			printf("%d是素数\n", a);
		else
			printf("%d不是素数\n", a);
	} while (a!= 0);
}

在这里插入图片描述
输出1–100之间的素数。

代码:

#include "stdio.h"
int main()
{
	int i, j,n=100;
	printf("%d\t ", 2);
	int t=1;
	for (i = 2; i <= n; i++)
	{
		for (j = 2; j * j <= i; j++)
		{
			if (i % j == 0)
				break;
		}
		if (i % j != 0)
		{
			t++;
			printf("%d\t ", i);
			if (t % 5 == 0)
			{
				printf("\n");
			}
		}
	}
	return 0;
}

C语言编程之素数的判定_第1张图片

你可能感兴趣的:(C语言编程之素数的判定)