main() { int day,x1,x2; day9; x21; while(day>0) {x1(x2+1)*2;/*第一天的桃子数是第2天桃子数加1后的2倍*/ x2x1; day--; } printf("the total is %d\n",x1); } |
main() { char i,j,k;/*i是a的对手,j是b的对手,k是c的对手*/ for(i'x';i<'z';i++) for(j'x';j<'z';j++) { if(i!j) for(k'x';k<'z';k++) { if(i!k&&j!k) { if(i!'x'&&k!'x'&&k!'z') printf("order is a--%c\tb--%c\tc--%c\n",i,j,k); } } } } |
「程序23」
题目:打印出如下图案(菱形)
*
***
******
********
******
***
*
1.程序分析:先把图形分成两部分来看待,前四行一个规律,后三行一个规律,利用双重for循环,第一层控制行,第二层控制列。
2.程序源代码:
main() { int i,j,k; for(i0;i<3;i++) { for(j0;j<2-i;j++) printf(" "); for(k0;k<2*i;k++) printf("*"); printf("\n"); } for(i0;i<2;i++) { for(j0;j<i;j++) printf(" "); for(k0;k<4-2*i;k++) printf("*"); printf("\n"); } } |
main() { int n,t,number20; float a2,b1,s0; for(n1;n<number;n++) { ss+a/b; ta;aa+b;bt;/*这部分是程序的关键,请读者猜猜t的作用*/ } printf("sum is %9.6f\n",s); } |
main() { float n,s0,t1; for(n1;n<20;n++) { t*n; s+t; } printf("1+2!+3!...+20!%e\n",s); } |
「程序26」
题目:利用递归方法求5!。
1.程序分析:递归公式:fnfn_1*4!
2.程序源代码:
#include "stdio.h" main() { int i; int fact(); for(i0;i<5;i++) printf("\40:%d!%d\n",i,fact(i)); } int fact(j) int j; { int sum; if(j0) sum1; else sumj*fact(j-1); return sum; } |
#include "stdio.h" main() { int i5; void palin(int n); printf("\40:"); palin(i); printf("\n"); } void palin(n) int n; { char next; if(n<1) { nextgetchar(); printf("\n\0:"); putchar(next); } else { nextgetchar(); palin(n-1); putchar(next); } } |
「程序28」
题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?
1.程序分析:利用递归的方法,递归分为回推和递推两个阶段。要想知道第五个人岁数,需知道第四人的岁数,依次类推,推到第一人(10岁),再往回推。
2.程序源代码:
age(n) int n; { int c; if(n1) c10; else cage(n-1)+2; return(c); } main() { printf("%d",age(5)); } |
main( ) { long a,b,c,d,e,x; scanf("%ld",&x); ax/10000;/*分解出万位*/ bx%10000/1000;/*分解出千位*/ cx%1000/100;/*分解出百位*/ dx%100/10;/*分解出十位*/ ex%10;/*分解出个位*/ if (a!0) printf("there are 5, %ld %ld %ld %ld %ld\n",e,d,c,b,a); else if (b!0) printf("there are 4, %ld %ld %ld %ld\n",e,d,c,b); else if (c!0) printf(" there are 3,%ld %ld %ld\n",e,d,c); else if (d!0) printf("there are 2, %ld %ld\n",e,d); else if (e!0) printf(" there are 1,%ld\n",e); } |
main( ) { long ge,shi,qian,wan,x; scanf("%ld",&x); wanx/10000; qianx%10000/1000; shix%100/10; gex%10; if (gewan&&shiqian)/*个位等于万位并且十位等于千位*/ printf("this number is a huiwen\n"); else printf("this number is not a huiwen\n"); } |