C语言循环例题

相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1.

//输出a和b之间的所有素数, 10个素数为一行输出

#include

#include

#include

int panDuanSuShu(int x) //判断x是否是素数

{

int i,m,flag; //flag为1表示是素数,flag为0表示不是素数 m=(int)sqrt(x);

if(x==2)

{ flag=1;}

else

{

for(i=2;i<=m;i++)

{

if(x%i==0)

{

flag=0;

break;

}

}

if(i>m)

{ flag=1; }

}

return flag;

}

int shuChuSuShu(int a,int b)

{

int i,k=0;//i是循环变量,k表示已经输出了k个素数

for(i=a;i<=b;i++)

{

if(panDuanSuShu(i)==1)

{

printf("%6d",i);

k++;

if(k%10==0)

{ printf("\n");}

}

}

printf("\n");

return k;

}

int main()

{

int a,b,t;

while(a<2||b<2)

{

printf("重新输入n和m:");

scanf("%d%d",&a,&b);

}

if(a>b)

{ t=a;a=b;b=t; }

printf("%d和%d之间共有%d个素数",a,b,shuChuSuShu(a,b));

printf("\n\n");

return 0;

}

2.

//用户输入2个数,输出这2个数之间所有的超素数

//超素数(质数)的概念:7193是素数,719是素数,71是素数,7是素数,则7193是素数#include

#include

#include

int isPrime(int n)//判断某数是否是素数

{

int i,f,m=(int)sqrt(n);

if(n==1) f=0;

else

{

for(i=2;i<=m;i++)

{

if(n%i==0)

break;

}

if(i>m) f=1;

else f=0;

}

return f;

}

int supperPrime(int n)//判断某数是否是超素数

{

int t=n;

while(t>0)

{

if(isPrime(t)==1)

t=t/10;

else

break;

}

}

void printSupperPrime(int a,int b)//输出a到b之间所有的超素数{

int i,m=0;

for(i=a;i<=b;i++)

{

if(supperPrime(i))

{ printf("%8d",i);

m++;

if(m%5==0)

printf("\n");

}

}

printf("\n");

}

int main()

{

int a,b,t;

printf("input a,b:");

scanf("%d%d",&a,&b);

while(a<2 || b<2)

{

printf("input a,b:");

scanf("%d%d",&a,&b);

}

if(a>b) {t=a;a=b;b=t;}

printSupperPrime(a,b);

printf("\n");

//system("pause");

return 0;

}

3.

//满足a*a+b*b==c*c的a,b,c三个数,称为勾股数

//编程输出100以内的所有勾股数

#include

#include

int gouGuShu()

{

int x=0;

for(int a=1;a<=100;a++)

for(int b=a;b<=100;b++)

for(int c=b;c<=100;c++)

if(x%4==0)

printf("\n");

printf("%4d%4d%4d ",a,b,c);

x++;

}

return x;

}

int main()

{

printf("\n\n 100以内的勾股数共有:%d个。\n",gouGuShu());

// system("pause");

return 0;

}

4.

//有一堆桃子,第一天猴子吃掉桃子的一半又多吃1个,第二天猴子再吃掉桃子的一半又多吃一个//第10天只剩下1个桃子,问最初有多少个桃子

#include

#include

int houZiChiTaoZi()

{

int day=10,x1,x2=1;

while(day>1)

{

x1=(x2+1)*2;

x2=x1;

day--;

}

return x1;

}

int main()

{

printf("最初桃子有%d个\n",houZiChiTaoZi());

//system("pause");

return 0;

}

5.

//由用户输入一个年份,再输入该年的元旦是星期几,再输入一个月份,则打印输出该月的日历。//例如:输入年份是2000年,输入元旦为星期6,输入月份为3,则输出:

//3月日一二三四五六

// 1 2 3 4

// 5 6 7 8 9 10 11

// 12 13 14 15 16 17 18

// 19 20 21 22 23 24 25

// 26 27 28 29 30 31

#include

相关文档
最新文档