2020-10-08

    科技2025-11-19  6

    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");
    Processed: 0.019, SQL: 8