编写一个程序判定一个数是否是素数,要求实现:调用isprime函数,输出50以内的素数
时间: 2023-07-14 22:11:58 浏览: 55
下面是 Python 语言的实现:
```python
def isprime(n):
if n <= 1:
return False
for i in range(2, int(n**0.5)+1):
if n % i == 0:
return False
return True
for i in range(2, 51):
if isprime(i):
print(i)
```
首先定义了一个判断素数的函数 `isprime(n)`,该函数返回布尔值,表示是否为素数。判断方法为:从 2 到 $\sqrt{n}$ 遍历所有整数,如果有整数能够整除 n,则 n 不是素数,否则 n 是素数。
然后在主程序中,从 2 到 50 遍历所有整数,如果是素数则输出。
相关问题
用c语言编写函数 fun,用以判定一个数是否为素数,提示: 可在函数中设置个逻辑量,并把该值返回给调用者·
以下是用 C 语言编写的判断素数的函数:
```c
#include <stdio.h>
int isPrime(int num) {
int i;
// 判断是否小于 2,小于 2 不是素数
if (num < 2) {
return 0;
}
// 判断是否为 2
if (num == 2) {
return 1;
}
// 判断是否为偶数,偶数不是素数
if (num % 2 == 0) {
return 0;
}
// 判断是否为奇数
for (i = 3; i < num; i += 2) {
if (num % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int n;
printf("请输入一个整数:");
scanf("%d", &n);
if (isPrime(n)) {
printf("%d是素数\n", n);
} else {
printf("%d不是素数\n", n);
}
return 0;
}
```
函数中使用了一个逻辑量,即 `num` 是否为素数。如果是素数,则返回 1,否则返回 0。在主函数中调用该函数,并根据返回值输出结果。注意,判断素数的循环从 3 开始,每次步长为 2,这是因为偶数已经在函数中被排除了。
编写一个函数,判定一个整数是否是素数。编写主程序,输入两个整数,输出这两个整数之间的所有素数,要求每行输出6个。c++
语言实现:
```
#include <stdio.h>
int isPrime(int n);
void printPrimes(int start, int end);
int main()
{
int start, end;
printf("请输入起始整数:");
scanf("%d", &start);
printf("请输入终止整数:");
scanf("%d", &end);
printf("素数如下:\n");
printPrimes(start, end);
return 0;
}
int isPrime(int n)
{
if(n <= 1)
{
return 0;
}
for(int i = 2; i * i <= n; i++)
{
if(n % i == 0)
{
return 0;
}
}
return 1;
}
void printPrimes(int start, int end)
{
int count = 0;
for(int i = start; i <= end; i++)
{
if(isPrime(i))
{
printf("%d ", i);
count++;
if(count == 6)
{
printf("\n");
count = 0;
}
}
}
printf("\n");
}
```
在该程序中,我们首先用 `isPrime()` 函数判断一个数是否为素数,若是返回 1 ,否则返回 0 。然后用 `printPrimes()` 函数输出两个整数之间的所有素数,每行输出 6 个。在 `main()` 函数中,先读入用户输入的两个整数,然后调用 `printPrimes()` 函数输出给定区间内的所有素数。
该程序输出的结果为:
```
请输入起始整数:1
请输入终止整数:50
素数如下:
2 3 5 7 11 13
17 19 23 29 31 37
41 43 47
```
这是在输入 `1` 和 `50` 的情况下的输出结果,共输出了三行,每行 6 个素数。