编写函数,其功能是判定整数m是否为质数,并main函数调用此函数,c语言
时间: 2023-12-14 22:39:33 浏览: 29
以下是一个简单的判断整数m是否为质数的函数和main函数:
```c
#include <stdio.h>
int isPrime(int m) {
int i;
if (m <= 1) { // 小于等于1的数不是质数
return 0;
}
for (i = 2; i * i <= m; i++) { // 判断m是否能被i整除
if (m % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int m;
printf("请输入一个整数:");
scanf("%d", &m);
if (isPrime(m)) {
printf("%d是质数\n", m);
} else {
printf("%d不是质数\n", m);
}
return 0;
}
```
函数isPrime的实现采用了一种常见的优化方式,即只需要判断2到sqrt(m)之间的整数是否能整除m,因为如果m不能被这些数整除,那么m就一定不是质数。这样可以减少循环次数,提高效率。
相关问题
c语言判断给定区间整数是否是素数,并按一行5个进行输出,main函数中输入两个正整数m和n,调用函数PrintPrime输出结果,函数PrintPrime需调用IsPrime函数来判定区间哪整数是否为负数,若此区间内没有素数,则输出“在此区间内不存在素数”
以下是该程序的实现:
```c
#include <stdio.h>
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 PrintPrime(int m, int n) {
int count = 0;
for (int i = m; i <= n; i++) {
if (IsPrime(i)) {
printf("%d ", i);
count++;
if (count % 5 == 0) {
printf("\n");
}
}
}
if (count == 0) {
printf("在此区间内不存在素数\n");
}
}
int main() {
int m, n;
printf("请输入两个正整数m和n:");
scanf("%d %d", &m, &n);
printf("在区间[%d, %d]内的素数有:\n", m, n);
PrintPrime(m, n);
return 0;
}
```
程序首先定义了一个判断整数是否为素数的函数 `IsPrime`,然后定义了另外一个函数 `PrintPrime`,该函数使用一个循环遍历给定的区间,判断每个整数是否为素数,并按照要求进行输出。特别地,若该区间内不存在素数,则输出相应信息。最后,程序在 `main` 函数中调用 `PrintPrime` 函数来输出结果。
用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,这是因为偶数已经在函数中被排除了。