C语言 素数判断,输出100以内的素数,用逗号分隔,第一个逗号不输出
2017-10-06 19:12
1591 查看
/* 质数(prime number)又称素数,有无限个。 质数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数,这样的数称为质数。 */ #include <stdio.h> int isPrime(int);//判断数n是不是素数 void printResult(int);//打印结果 int main() { int i; printf("0到100之内的素数:\n"); for(i=0;i<100;i++) { printResult(i); } return 0; } /* 质数(prime number)又称素数,有无限个。 质数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数,这样的数称为质数。 */ int isPrime(int n)//判断数n是不是素数 { if(n<=1) return -1;//返回-1表示这个数应该大于1; int i; int IsPrime=1;//默认不是质数 //for(i=2;i<=n/2;i++) //一个数 n 如果是合数,那么它的所有的因子不超过sqrt(n) for(i=2;i<=sqrt(n);i++) { if(n%i==0)//如果有其他因数 { IsPrime=0;//那就不是质数,用0表示 break;//退出循环 } } return IsPrime;//返回标志 } void printResult(int n) { static int count=0;//加上static静态局部变量,这样只有第一次调用函数的时候count的值为1 int flag=isPrime(n);//判断 if(flag==-1) printf("素数是大于1的整数!n=%d输入错误!n要是大于1的整数\n",n); else if (flag) { if(count==1)//第一次调用函数时,count为0,第一个逗号不输出,以后count都为1 输出逗号分隔素数 printf(","); printf("%-2d",n); count=1; } }
结果:
0到100之内的素数: 素数是大于1的整数!n=0输入错误!n要是大于1的整数 素数是大于1的整数!n=1输入错误!n要是大于1的整数 2 ,3 ,5 ,7 ,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97
java实现:
package Ctojava;
public class PrintPrime100
{
public static void main(String[] args)
{
boolean printComma=false;
for(int i=0;i<=100;i++)
{
if(isPrime(i))
{
if(printComma)
System.out.print(",");
else
printComma=true;
System.out.print(i);
}
}
}
public static boolean isPrime(int n)
{
if(n<=1)
return false;
for(int i=2;i<=Math.sqrt(n);i++)
{
if(n%i==0)//如果找到一个因数
return false;//那就不是质数
}
//如果没有找到因数
return true;//那就是
}
}
结果:
2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97
相关文章推荐
- C语言如何判断一个数是素数,输出100-200之间的全部素数。
- 使用c语言判断100以内素数的示例(c语言求素数)
- 判断素数和输出100以内的素数
- 函数实现判断素数并调用函数输出100以内所有素数
- 判断并输出100以内的所有素数
- 如何用T-SQL使用最短的语句输出100以内素数?
- GO 语言冒泡排序、输出100以内所以素数的小程序
- 输出100以内所有素数
- 写一函数判断一个整数是否是素数。在main函数中调用该函数输出2~100中所有素数。
- 筛选法输出100以内的所有素数
- 实训JAVA语言设计——判断出100以内的素数
- C语言之判断100~200之间的素数(质数)
- 输出100以内素数,1000以内完数,以及1000以内有多少个9.
- 输出100以内的所有素数
- JAVA面试题:输出100以内所有的素数
- JAVA 面试题 输出100以内的所有素数
- 用vb程序设计输出100以内素数和
- Java课后习题——编写程序求100以内的素数并输出
- 1. 打印100~200 之间的素数 2. 输出乘法口诀表 3. 判断1000年---2000年之间的闰年
- 编写程序输出100以内的素数