C语言质数判断。从键盘输入一个正整数n,判断n是否为质数。
时间: 2024-05-14 07:15:38 浏览: 228
以下是C语言代码实现:
```c
#include <stdio.h>
int main() {
int n, flag = 0; // flag为标记变量,初值为0
printf("请输入一个正整数: ");
scanf("%d", &n);
if (n <= 1) {
printf("%d不是质数\n", n);
return 0;
}
for (int i = 2; i <= n / 2; i++) {
if (n % i == 0) {
flag = 1; // 若n能被i整除,则标记flag变为1
break;
}
}
if (flag == 0) {
printf("%d是质数\n", n);
} else {
printf("%d不是质数\n", n);
}
return 0;
}
```
代码说明:
1. 首先通过 `scanf()` 函数从键盘输入一个正整数 `n`。
2. 对于小于等于1的数,直接输出不是质数。
3. 利用循环从2开始,逐个判断 `n` 能否被整除。
4. 如果 `n` 能被一个数整除,则说明 `n` 不是质数,将标记 `flag` 置为1,跳出循环。
5. 最后判断标记 `flag` 的值,若为0则说明 `n` 是质数,否则不是质数。
相关问题
从键盘输入一个正整数n,判断n是否为质数。C语言
在C语言中,判断一个正整数n是否为质数,通常的做法是检查它是否只有两个因子:1和n本身。如果存在其他因子,那么n就不是质数。以下是简单的代码实现:
```c
#include <stdio.h>
#include <stdbool.h> // 使用bool类型
bool isPrime(int n) {
if (n <= 1) { // 质数定义排除1
return false;
} else if (n == 2) { // 2是唯一的偶数质数
return true;
} else if (n % 2 == 0) { // 偶数不是质数,除了2
return false;
}
// 从3开始,每次加2,直到sqrt(n),因为大于n的因子必定有小于等于√n的一个
for(int i = 3; i * i <= n; i += 2) {
if (n % i == 0) {
return false; // 找到了因子,n不是质数
}
}
return true; // 没有找到因子,说明n是质数
}
int main() {
int n;
printf("请输入一个正整数:");
scanf("%d", &n);
if(isPrime(n)) {
printf("%d是质数。\n", n);
} else {
printf("%d不是质数。\n", n);
}
return 0;
}
```
在这个程序中,我们首先检查一些基本情况,然后遍历奇数(因为偶数除2外都不是质数),看是否存在因子。
使用c++质数判断。从键盘输入一个正整数n,判断n是否为质数
质数是指只能被1和自身整除的正整数,因此可以通过遍历2到n-1之间的所有数,判断是否能够被n整除来判断n是否为质数。以下是使用c语言实现的代码:
```c
#include <stdio.h>
int main() {
int n, i, flag = 0;
printf("请输入一个正整数:");
scanf("%d", &n);
for (i = 2; i < n; i++) {
if (n % i == 0) {
flag = 1; // 标记不是质数
break;
}
}
if (flag == 0) {
printf("%d是质数\n", n);
} else {
printf("%d不是质数\n", n);
}
return 0;
}
```
首先从键盘输入一个正整数n,然后遍历2到n-1之间的所有数,如果n能够被其中的某个数整除,则说明n不是质数,标记为flag=1并跳出循环;否则n是质数,flag保持为0。最后根据flag的值输出判断结果。
阅读全文
相关推荐














