C语言经典题目(一)
1.有1.2.3.4四个数字,能组成多少个互不相同且无重复数字的三位数,都是多少?
for (i=0;i<4;i++)
{
for (j=0;j<4;j++)
{
for (k=0;k<4;k++)
{
if(i!=j && j!=k &&k!=i)//判断无重复
{
number=arr[i]*100+arr[j]*10+arr[k];
printf("%d\t",number);
count++;
}
}
}
}
printf("\r\n");
printf("%d\r\n",count);
2.一个整数,它加上100后是-个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
for(i=0;i<1000;i++)
{
a = 100 + i;
b = 100 + 168 +i;
x=sqrt(a);
y=sqrt(b);
m = x - (int) x;
n = y - (int) y;
if(m==0&&n==0)
{
printf("%d\t",i);
}
}
printf("\r\n");
3.输入某年某月某日,判断这-天是这- 年的第几天?
int main()
{
int i = 0;
int year,month,day=0;
int num_day = 0;
int arr[2][12]={{31,29,31,30,31,30,31,31,30,31,30,31},{31,28,31,30,31,30,31,31,30,31,30,31}};//分为闰年和平年
printf("please input year/month/day\r\n");
scanf("%d/%d/%d",&year,&month,&day);
if(0 == (year % 4) && (year % 100)!=0 || 0 == (year % 400))//判断是否为闰年
{
for(i=0;i<month-1;i++)
{
num_day+=arr[0][i];
}
}
else
{
for(i=0;i<month-1;i++)
{
num_day+=arr[1][i];
}
}
printf("the day you choose is NO:%d day\r\n",num_day+day);
return 0;
}
4.输出9*9口诀。
for(i=1;i<10;i++)
{
for(j=1;j<=i;j++)
{
printf("%d * %d = %d\t",j,i,i*j);
}
printf("\r\n");
}
5.古典问题(兔子生崽) : 有- -对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生- -对兔子 ,假如兔子都不死,问每个月的兔子总数为多少? (输出前40个月即可)(斐波那契数列)。
#include <stdio.h>
int main(int argc,char **argv)
{
long int i =1 , j = 1;
long int num = 0;
long int n = 0;
printf("%ld\r\n",i);
printf("%ld\r\n",j);
for(n=0;n<38;n++)
{
num = i + j ;
printf("%ld\r\n",num);
i = num;
j = i - j;
}
return 0;
}
7.判断101到200之间的素数。
for(i=101;i<=200;i++)
{
for(j=2;j<=100;j++)
{
if( 0 == i % j)//能整除
{
count++;
}
}
if( 0 == count )//count为0,为素数
{
printf("%d\t",i);
}
count = 0 ;//清空
}
printf("\r\n");
8.打印出所有的“水仙花数”, 所谓"水仙花数”是指一一个三位数,其各位数字立方和等于该数本身例如: 153是一个“水仙花数”,因为153= 1的三次方+5的三次方+3的三次方。(类似的还有四叶玫瑰数、五角星数等)
for(i=100;i<1000;i++)
{
a = i / 100;
b = i / 10 - 10 * a;
c = i % 10;
if(a*a*a+b*b*b+c*c*c==i)
{
printf("%d\t",i);
}
}
printf("\r\n");