C语言循环例题

C语言循环例题
C语言循环例题

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;

printf("输入a与b,以便求a与b之间的所有素数\n");

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

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;

}

if(t==0) return 1;

else return 0;

}

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(a*a+b*b==c*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

#include

int LeepYear(int y)//判断某年就是否就是闰年

{

if(y%4==0&&y%100!=0||y%400==0)

return 1;

else

return 0;

相关主题
相关文档
最新文档