离去之原中文歌词:程序错在哪里

来源:百度文库 编辑:高校问答 时间:2024/05/04 19:54:32
#include <math.h>
int c(int m)
{int k,i;
k=sqrt(m);
for(i=2;i<=k;i++)
if(m%i==0)break;
if(i>k)return 1;
else return 0;
}
main()
{
int i=0,a[20],b[20],m,x,k=0,j,m1,n,y;
clrscr();
for(m=2;m<=50;m++)
{x=c(m);
if(x==1)
a[i++]=m;
}
for(m1=0;m1<i;m++)
y=a[m1+1]-a[m1];
b[k++]=y;
for(n=0;n<k;n++)
printf(" %d",b[n]);
}
改成m1
运行结果也是错

#include <stdio.h>
#include <math.h>
#define NOARR 20//定义数组长度
int c(int m){
int k,i;
k=(int)sqrt(m);
for(i=2;i<=k;i++)
if(m%i==0)break;
if(i>k)
return 1;//has no submultiple
else
return 0;//has submultiple
}
int main()
{
int i=0,a[NOARR],b[NOARR],m,k=0,m1,n,y;
for(m=2;m<=50;m++){
if(c(m)) a[i++]=m;// 选出所有没有因数的数(包括2)
if(i==NOARR)break;//防止数组越界访问
}
for(m1=0;m1<i-1;m1++){
y=a[m1+1]-a[m1];
b[k++]=y;
if(k==NOARR)break;
}
for(n=0;n<k;n++)
printf("%d\t",b[n]);
return 0;
}
//注意数组访问越界的问题,之前多出地方都存在越界的隐患
改进函数c
int c(int m){
int k,i;
k=(int)sqrt(m);
for(i=2;i<=k;i++)
if(m%i==0)return 0;//has submultiple
return 1;//has no submultiple
}

说说你要实现什么?
反正是死循环我发现。
for(m1=0;m1<i;m++)明显有错,m++应该是m1++