C语言编程,求500以内的全部素数,每行输出10个。可以提高悬赏哦!

 我来答
仙戈雅3n
推荐于2017-09-29 · TA获得超过5789个赞
知道大有可为答主
回答量:2398
采纳率:75%
帮助的人:873万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

inline bool IsPrimeNumbers(int n){
if (n < 2) return false;//1既不是合数又不是质数(素数),所以排除,2是最小质数
// 对n开方,目的在于减少循环次数,原理:因数在根的前面都没有,则后面肯定不会有
int k = (int)sqrt((double)n);  

for (int i = 2; i <= k;i++)
{
if (n%i == 0) return false;
}
return true;
}

int main(){

int count = 0;  // 计数器,记录每行输出了多少个

for (int i = 2; i <= 500;i++)
{
if (IsPrimeNumbers(i)){
printf("%d ", i);
count++;
if (count % 10 == 0) printf("\n");  // 取模 每10个换行
}
}

printf("\n");
system("pause");  // 屏幕暂停
return 1;
}
夜礼服假面MP
推荐于2017-09-14 · TA获得超过3437个赞
知道大有可为答主
回答量:1034
采纳率:77%
帮助的人:346万
展开全部
#include "stdio.h"
void main()
{
 int a,b;
 int i,n;
 int flag=1;
 int tmp =0;
 printf("请输入上限:");
 scanf("%d",&a);
 printf("请输入下限:");
 scanf("%d",&b);
 
 printf("%d到%d之间的素数为:",a,b);
 for (i=a;i<=b;i++) {
  flag=1;
  for (n=2;n<i;n++) {
   if (i%n==0) {
    flag=0;
   }
  }
  if ((flag==1)&&(i!=1)) {
   printf("%d\t",i);
   tmp ++;
   if(tmp%10 == 0)
       printf("\n");
  }

 }

}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
愛倪h
2014-10-27 · TA获得超过471个赞
知道小有建树答主
回答量:397
采纳率:100%
帮助的人:165万
展开全部
#include<stdio.h>
int prime(int n);
int main(void)
{
int i,k=0;
for(i=2;i<=500;i++)
{
if(prime(i)){
printf("%4d",i);
k++;
if(k%10==0)
printf("\n");
}
}
printf("\n");
return 0;
}
int prime(int n)
{
int i;
if(n==1&&n==0)
return 0;
for(i=2;i<=n/2;i++)
if(n%i==0)
return 0;
return 1;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
兎姩駃樂
2014-10-27 · TA获得超过142个赞
知道小有建树答主
回答量:357
采纳率:33%
帮助的人:36.3万
展开全部
编一个循环嵌套,外层识别素数,内层控制输出十个一行
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式