C语言,求输入的两个数之间的所有素数
#include <stdlib.h>
int main()
{
int a,b,m,k,t;
scanf("%d%d",&a,&b);
if(a>=b){
t=a;
a=b;
b=t;
}
else {for(k=a;k<=b;k++)
for(m=2;m<=k-1;m++)
if(k%m!=0)
printf("%d ",k);}
return 0;
}
请看一下这个程序哪里错了 展开
#include <stdio.h>
int main()
{
int a,b;
printf("please input two numbers \n");
scanf("%d %d",&a,&b);
prime(a,b);
return 0;
}
int prime(int x,int y)
{
int i,j,k,cout;
cout=0;
for(i=x;i<=y;i++)
{
k=1;
for(j=2;j<=i/2;j++)
{
if(i%j==0)
{
k=0;
break;
}
}
if(k)
{
printf("%d \n",i);
cout++;
}
}
printf("there are %d numbers from %d to %d \n",cout,x,y);
return 0;
}
扩展资料:
scanf函数用法:
scanf("输入控制符",输入参数);
功能:将从键盘输入的字符转化为“输入控制符”所规定格式的数据,然后存入以输入参数的值为地址的变量中。
用scanf()函数以%s格式读入的数据不能含有空白符时,所有空白符都被当做数据结束的标志。所以题中函数输出的值只有空格前面的部分。
如果想要输出包括空格在内的所有数据,可以使用gets()函数读入数据。gets()函数的功能是读取字符串,并存放在指定的字符数组中,遇到换行符或文件结束标志时结束读入。换行符不作为读取串的内容,读取的换行符被转换为字符串结束标志'\0'。
推荐于2017-09-15 · 知道合伙人教育行家
思路:先定义一个isp函数用来判断一个数是否是素数,接着就依次遍历两个数之间的所有数,判断其是否是素数,是就输出该数。
参考代码:输出9到100之间的所有素数(可以输入9 100也可以输入100 9,即数字大小顺序不限制)
#include<stdio.h>
bool isp(int n)//求矩阵n列的累加和
{
int i;
for(i=2;i<n;i++)
if(n%i==0) return false;
return true;
}
int main()
{
int a,b,i;
scanf("%d%d",&a,&b);
if(a>b){
t=a;
a=b;
b=t;
}
for(i=a;i<=b;i++)
if(isp(i))
printf("%d ",i);
return 0;
}
/*
输出:
100 9
11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97
*/
望采纳
#include <stdio.h>
#include <stdlib.h>
int main()
{
int a,b,m,k,t,flag;
scanf("%d%d",&a,&b);
if(a>=b){
t=a;
a=b;
b=t;
}
for(k=a;k<=b;k++)
{
flag=1;
for(m=2;m<=k-1;m++)
if(k%m==0)
flag=0;
if(flag==1&&k!=1)//1不是素数
printf("%d ",k);
}
printf("\n");
return 0;
}
#include <stdlib.h>
#include <math.h>
int main()
{
int a,b,m,k,t,n;
scanf("%d%d",&a,&b);
if(a>=b)
{
t=a;
a=b;
b=t;
}
for(k=a;k<=b;k++)
{ n=(int)sqrt(k);
for(m=2;m<=n;m++)
if(k%m==0)
break;
if(m==n+1)
printf("%d ",k);
}
return 0;
}
对照着参考下吧,望采纳
for(m=2;m<=k-1;m++)
if(k%m!=0)
printf("%d ",k);}
return 0;
}
请问这里哪里错了?
追问采纳者吧,亲。木有心情回答了