解题思路:只需判断是否为素数即可。

注意事项:注意这一题是没有输入数据的,导致我忽略这个问题,一直答案错误。

参考代码:#include<stdio.h>
#include<math.h>
int sushu(int x)
{
 int i,flag=1;
 for(i=2;i<=sqrt(x);i++)
 {
  if(x%i==0)
  {
   flag=0;break;
  }
 }
 return flag;
}
int main()
{
 int a,b,i,c,count=0;
 for(i=100;i<=200;i++)
 {
  c=sushu(i);
  if(c==1)
  {
   count++;
  }
  
 }
 printf("%d\n",count);
 for(i=100;i<=200;i++)
 {
  c=sushu(i);
  if(c==1&&count>0)
  {
   count--;
    printf("%d ",i);continue;
  }
 }
 return 0;
}

点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

Brynn 3年前 回复TA
为什么我的不行???
#include<stdio.h>
#include<math.h>
int main()
{
    int sushu(int i);
    int i,count=0,a[100],j;
    for(i=100;i<=200;i++)
    {
        if(sushu(i))
        {
            count++;
            for(j=0;j<100;j++)
            {
                a[j]=i;
            }
        }
    }
    printf("%d\n",count);
    for(j=0;j<count;j++)
    printf("%d ",a[j]);
    return 0;
}

int sushu(int i)
{
    int j,s;
    s=sqrt(i);
    for(j=2;j<=s;j++)
        if(i%j==0)
        return 0;
    return (1);
}