c语言判断素数pta
时间: 2023-11-10 19:07:29 浏览: 256
题目要求实现一个函数,判断函数参数传递过来的数是否素数。如果是素数,函数的返回值就是该数,否则函数的返回值为0。我们可以使用引用中提供的函数接口定义,编写如下代码:
int IsPrime(int number){
int i;
if(number==0) return 0;
if(number==1) return 0;
for(i=2;i<=sqrt(number);i++)
if(number%i==0) break;
if(i<=sqrt(number)) return 0;
else return number;
}
在主函数中,我们可以通过调用IsPrime函数来判断一个数是否为素数,代码如下:
#include <stdio.h>
#include <math.h>
int IsPrime(int number);
int main() {
int number;
scanf("%d",&number);
if(IsPrime(number))
printf("%d is prime number.\n",number);
else
printf("%d is not prime number.\n",number);
return 0;
}
需要注意的是,我们需要在程序开头引入math.h头文件,以便使用sqrt函数来计算平方根。
相关问题
判断素数pta c语言
要判断一个数是否为素数,可以编写一个函数IsPrime()来实现。该函数接收一个整数作为参数,如果该数是素数,函数返回该数,否则返回0。以下是一个示例的C语言代码:
```c
#include <stdio.h>
#include <math.h>
int isPrime(int n) {
int i;
if (n == 0 || n == 1) {
return 0;
}
for (i = 2; i <= sqrt(n); i++) {
if (n % i == 0) {
return 0;
}
}
return n;
}
int main() {
int n;
scanf("%d", &n);
if (isPrime(n) == n) {
printf("%d is a prime number.", n);
} else {
printf("%d is not a prime number.", n);
}
return 0;
}
```
以上代码中,首先定义了一个函数isPrime()来判断素数。在函数内部,如果输入的数为0或1,直接返回0,因为0和1不是素数。然后通过for循环从2开始到该数的平方根,判断是否能整除该数,如果能整除则不是素数,返回0;如果不能整除,则是素数,返回该数本身。在主函数main()中,先通过scanf函数从键盘输入一个整数n,然后调用isPrime()函数判断n是否为素数,根据返回值输出相应的结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [【PTA】【C语言】判断给定整数是否素数[加强版]](https://blog.csdn.net/yewanyuan/article/details/123488757)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
判断素数pta+c语言
以下是一个判断素数的C语言程序,使用了for循环和isprime函数:
```c
#include <stdio.h>
int isprime(int n);
int main() {
int m, n;
scanf("%d%d", &m, &n);
for (int i = m; i <= n; i++) {
if (isprime(i)) {
printf("%d ", i);
}
}
return 0;
}
int isprime(int n) {
int ret = 1;
if (n == 2) {
ret = 1;
}
if (n < 2) {
ret = 0;
}
for (int i = 2; i < n / 2; i++) {
if (n % i == 0) ret = 0;
}
return ret;
}
```
该程序通过输入两个整数m和n,遍历m到n之间的所有整数,判断它们是否为素数,如果是素数则输出。
阅读全文