#include <stdio.h>
int main()
{
int a=0
int num=0
int i
printf("输入一个整数:")
scanf("%d",&num)
for(i=2i<numi++){
if(num%i==0){
a++
}
}
if(a==0){
printf("%d是素数。\n", num)
}else{
printf("%d不是素数。\n", num)
}
return 0
}
扩展资料:
质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数。
基本算法:若 k%m==0 则说明 k 不是素数。
判断整数n是否为素数——采用枚举法求解。
采用枚举算法解题的基本思路:
(1)确定枚举对象、枚举范围和判定条件;
(2)枚举可能的解,验证是否是问题的解。
枚举算法的一般结构:while循环。
参考资料来源:百度百科-枚举法
//我分别写出了求素数和判断素数的程序/*
//判断一个数是否为素数
#include<stdio.h>
#include<math.h>
int isprime(int)
void main()
{
int inumber
printf("请输入一个非负整数: ")
scanf("%d",&inumber)
if(isprime(inumber))
printf("%d是素数!\n",inumber)
else
printf("%d不是素数!\n",inumber)
}
int isprime(int a)
{
int i
for(i=2i<=sqrt(a)i++)
if(a%i==0)
return 0
return 1
}
*/
/*****************************************************/
//求某个正整数以内的素数
#include"stdio.h"
#include"math.h"
int main(void)
{
int count,i,m,n,num
printf("请输入所求范围(正整数): ")
scanf("%d",&num)
count=0//count记录素数的个数
printf("%d以内的素数为:\n",num)
for(m=2m<=numm++)
{
n=sqrt(m)
for(i=2i<=ni++)
{
if(m%i==0)
break
}
if(i>n)//如果m是素数
{
printf("%6d",m)
count++
if(count%10==0)//count为10的倍数时换行
printf("\n")
}
}
printf("\n")
return 0
}
分类: 电脑/网络 >>程序设计 >>其他编程语言问题描述:
大哥大姐帮忙呀!
解析:
#include <stdio.h>
#include <math.h>
bool IsPrime(int n)
void main(void)
{
for (int i = 2i <= 100i ++)
{
if (IsPrime(i))
{
printf("%d是质数\r\n", i)
}
}
}
bool IsPrime(int n)
{
int nRoot = int(sqrtf(n))
for (int i = 2i <nRooti ++)
{
if (n % i == 0)
return false
}
return true
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)