




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、C語(yǔ)言100例及分析教案【程序1】題目:有1、2、3、4個(gè)數(shù)字,能組成多少個(gè)互不相同且無重復(fù)數(shù)字的三位數(shù)?都是多少?1.程序分析:可填在百位、十位、個(gè)位的數(shù)字都是1、2、3、4。組成所有的排列后再去掉不滿足條件的排列。 2.程序源代碼:#include stdio.h#include conio.hmain() int i,j,k; printf(n); for(i=1;i5;i+) /*以下為三重循環(huán)*/ for(j=1;j5;j+) for (k=1;k5;k+) if (i!k&i!j&j!k) /*確保i、j、k三位互不相同*/ printf(%d,%d,%dn,i,j,k); get
2、ch();【程序2】題目:企業(yè)發(fā)放的獎(jiǎng)金根據(jù)利潤(rùn)提成。利潤(rùn)(I)低于或等于10萬元時(shí),獎(jiǎng)金可提10%;利潤(rùn)高于10萬元,低于20萬元時(shí),低于10萬元的部分按10%提成,高于10萬元的部分,可可提成7.5%;20萬到40萬之間時(shí),高于20萬元的部分,可提成5%;40萬到60萬之間時(shí)高于40萬元的部分,可提成3%;60萬到100萬之間時(shí),高于60萬元的部分,可提成1.5%,高于100萬元時(shí),超過100萬元的部分按1%提成,從鍵盤輸入當(dāng)月利潤(rùn)I,求應(yīng)發(fā)放獎(jiǎng)金總數(shù)?1.程序分析:請(qǐng)利用數(shù)軸來分界,定位。注意定義時(shí)需把獎(jiǎng)金定義成長(zhǎng)整型。2.程序源代碼:#include stdio.h#include c
3、onio.hmain() long int i; int bonus1,bonus2,bonus4,bonus6,bonus10,bonus; scanf(%ld,&i); bonus1100000*0. 1; bonus2bonus1+100000*0.75; bonus4bonus2+200000*0.5; bonus6bonus4+200000*0.3; bonus10bonus6+400000*0.15; if(i100000) bonusi*0.1; else if(i200000) bonusbonus1+(i-100000)*0.075; else if(i400000) bon
4、usbonus2+(i-200000)*0.05; else if(i600000) bonusbonus4+(i-400000)*0.03; else if(i1000000) bonusbonus6+(i-600000)*0.015; else bonusbonus10+(i-1000000)*0.01; printf(bonus%d,bonus); getch(); 【程序3】題目:一個(gè)整數(shù),它加上100后是一個(gè)完全平方數(shù),再加上168又是一個(gè)完全平方數(shù),請(qǐng)問該數(shù)是多少?1.程序分析:在10萬以內(nèi)判斷,先將該數(shù)加上100后再開方,再將該數(shù)加上268后再開方,如果開方后的結(jié)果滿足如下條件,
5、即是結(jié)果。請(qǐng)看具體分析:2.程序源代碼:#include math.h#include stdio.h#include conio.hmain() long int i,x,y,z; for (i=1;i2) /*如果是閏年且月份大于2,總天數(shù)應(yīng)該加一天*/ sum+; printf(It is the %dth day.,sum); getch(); 【程序5】題目:輸入三個(gè)整數(shù)x,y,z,請(qǐng)把這三個(gè)數(shù)由小到大輸出。1.程序分析:我們想辦法把最小的數(shù)放到x上,先將x與y進(jìn)行比較,如果xy則將x與y的值進(jìn)行交換,然后再用x與z進(jìn)行比較,如果xz則將x與z的值進(jìn)行交換,這樣能使x最小。2.程序源
6、代碼:#include stdio.h#include conio.hmain() int x,y,z,t; scanf(%d%d%d,&x,&y,&z); if (xy) tx;xy;yt; /*交換x,y的值*/ if(xz) tz;zx;xt; /*交換x,z的值*/ if(yz) ty;yz;zt; /*交換z,y的值*/ printf(small to big: %d %d %dn,x,y,z); getch(); 【程序6】題目:用*號(hào)輸出字母C的圖案。1.程序分析:可先用*號(hào)在紙上寫出字母C,再分行輸出。2.程序源代碼:#include stdio.h#include conio
7、.hmain() printf(Hello C-world!n); printf( *n); printf( *n); printf( * n); printf( *n); getch(); 【程序7】題目:輸出特殊圖案,請(qǐng)?jiān)赾環(huán)境中運(yùn)行,看一看,Very Beautiful!1.程序分析:字符共有256個(gè)。不同字符,圖形不一樣。2.程序源代碼:#include stdio.h#include conio.hmain() char a176,b219; printf(%c%c%c%c%cn,b,a,a,a,b); printf(%c%c%c%c%cn,a,b,a,b,a); printf(%c
8、%c%c%c%cn,a,a,b,a,a); printf(%c%c%c%c%cn,a,b,a,b,a); printf(%c%c%c%c%cn,b,a,a,a,b); getch(); 【程序8】題目:輸出9*9口訣。1.程序分析:分行與列考慮,共9行9列,i控制行,j控制列。2.程序源代碼:#include stdio.h#include conio.hmain() int i,j,result; printf(n); for (i1;i10;i+) for(j1;j10;j+) resulti*j; printf(%d*%d%-3d,i,j,result); /*-3d表示左對(duì)齊,占3位*
9、/ printf(n); /*每一行后換行*/ getch();【程序9】題目:要求輸出國(guó)際象棋棋盤。1.程序分析:用i控制行,j來控制列,根據(jù)i+j的和的變化來控制輸出黑方格,還是白方格。2.程序源代碼:#include stdio.h#include conio.hmain() int i,j; for(i=0;i8;i+) for(j=0;j8;j+) if(i+j)%2=0) printf(%c%c,219,219); else printf( ); printf(n); getch(); 【程序10】題目:打印樓梯,同時(shí)在樓梯上方打印兩個(gè)笑臉。 1.程序分析:用i控制行,j來控制列,
10、j根據(jù)i的變化來控制輸出黑方格的個(gè)數(shù)。2.程序源代碼:#include stdio.h#include conio.hmain() int i,j; printf(11n); /*輸出兩個(gè)笑臉*/ for(i=1;i11;i+) for(j1;ji;j+) printf(%c%c,219,219); printf(n); getch(); 【程序11】題目:古典問題:有一對(duì)兔子,從出生后第3個(gè)月起每個(gè)月都生一對(duì)兔子,小兔子長(zhǎng)到第三個(gè)月后每個(gè)月又生一對(duì)兔子,假如兔子都不死,問每個(gè)月的兔子總數(shù)為多少?1.程序分析:兔子的規(guī)律為數(shù)列1,1,2,3,5,8,13,21.2.程序源代碼:#include
11、 stdio.h#include conio.hmain() long f1,f2; int i; f1f21; for(i1;i20;i+) printf(%12ld %12ld,f1,f2); if(i%2=0) printf(n); /*控制輸出,每行四個(gè)*/ f1f1+f2; /*前兩個(gè)月加起來賦值給第三個(gè)月*/ f2f1+f2; /*前兩個(gè)月加起來賦值給第三個(gè)月*/ getch();【程序12】題目:判斷101-200之間有多少個(gè)素?cái)?shù),并輸出所有素?cái)?shù)。1.程序分析:判斷素?cái)?shù)的方法:用一個(gè)數(shù)分別去除2到sqrt(這個(gè)數(shù)),如果能被整除,則表明此數(shù)不是素?cái)?shù),反之是素?cái)?shù)。 2.程序源代碼:
12、#include stdio.h#include conio.h#include math.hmain() int m,i,k,h=0,leap1; printf(n); for(m=101;m200;m+) k=sqrt(m+1); for(i=2;ik;i+) if(m%i=0) Leap=0; break; if(leap) printf(%-4d,m); h+; if(h%10=0) printf(n); leap1; printf(nThe total is %d,h); getch();【程序13】題目:打印出所有的“水仙花數(shù)”,所謂“水仙花數(shù)”是指一個(gè)三位數(shù),其各位數(shù)字立方和等于
13、該數(shù)本身。例如:153是一個(gè)“水仙花數(shù)”,因?yàn)?531的三次方5的三次方3的三次方。1.程序分析:利用for循環(huán)控制100-999個(gè)數(shù),每個(gè)數(shù)分解出個(gè)位,十位,百位。2.程序源代碼:#include stdio.h#include conio.hmain() int i,j,k,n; printf(water flowernumber is:); for(n100;n1000;n+) in/100;/*分解出百位*/ jn/10%10;/*分解出十位*/ kn%10;/*分解出個(gè)位*/ if(i*100+j*10+ki*i*i+j*j*j+k*k*k) printf(%-5d,n); getc
14、h();【程序14】題目:將一個(gè)正整數(shù)分解質(zhì)因數(shù)。例如:輸入90,打印出902*3*3*5。程序分析:對(duì)n進(jìn)行分解質(zhì)因數(shù),應(yīng)先找到一個(gè)最小的質(zhì)數(shù)k,然后按下述步驟完成: (1)如果這個(gè)質(zhì)數(shù)恰等于n,則說明分解質(zhì)因數(shù)的過程已經(jīng)結(jié)束,打印出即可。(2)如果nk,但n能被k整除,則應(yīng)打印出k的值,并用n除以k的商,作為新的正整數(shù)你n,重復(fù)執(zhí)行第一步。(3)如果n不能被k整除,則用k+1作為k的值,重復(fù)執(zhí)行第一步。2.程序源代碼:/* zheng int is divided yinshu*/#include stdio.h#include conio.hmain() int n,i; printf(
15、nplease input a number:n); scanf(%d,&n); printf(%d,n); for(i2;i90分的同學(xué)用A表示,60-89分之間的用B表示,60分以下的用C表示。1.程序分析:(ab)?a:b這是條件運(yùn)算符的基本例子。2.程序源代碼:#include stdio.h#include conio.hmain() int score; char grade; printf(please input a scoren); scanf(%d,&score); gradescore90?A:(score60?B:C); printf(%d belongs to %c,
16、score,grade); getch();【程序16】題目:輸入兩個(gè)正整數(shù)m和n,求其最大公約數(shù)和最小公倍數(shù)。1.程序分析:利用輾除法。2.程序源代碼:#include stdio.h#include conio.hmain() int a,b,num1,num2,temp; printf(please input two numbers:n); scanf(%d,%d,&num1,&num2); if(num1a&cA&c0&c9) digit+; else others+; printf(all in all:char%d space%d digit%d others%dn,letter
17、s, space,digit,others); getch();【程序18】題目:求sa+aa+aaa+aaaa+aa.a的值,其中a是一個(gè)數(shù)字。例如2+22+222+2222+22222(此時(shí)共有5個(gè)數(shù)相加),幾個(gè)數(shù)相加有鍵盤控制。1.程序分析:關(guān)鍵是計(jì)算出每一項(xiàng)的值。2.程序源代碼:#include stdio.h#include conio.hmain() int a,n,count1; long int sn0,tn0; printf(please input a and nn); scanf(%d,%d,&a,&n); printf(a%d,n%dn,a,n); while(coun
18、tn) tntn+a; snsn+tn; aa*10; +count; printf(a+aa+.%ldn,sn); getch();【程序19】題目:一個(gè)數(shù)如果恰好等于它的因子之和,這個(gè)數(shù)就稱為“完數(shù)”。例如6123.編程找出1000以內(nèi)的所有完數(shù)。1. 程序分析:請(qǐng)參照程序-上頁(yè)程序14. 2.程序源代碼:#include stdio.h#include conio.hmain() static int k10; int i,j,n,s; for(j2;j1000;j+) n-1; sj; for(i1;ij;i+) if(j%i)0) n+; ss-i; kni; if(s0) prin
19、tf(%d is a wanshu,j); for(i0;in;i+) printf(%d,ki); printf(%dn,kn); getch(); 【程序20】題目:一球從100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地時(shí),共經(jīng)過多少米?第10次反彈多高?1.程序分析:見下面注釋2.程序源代碼:#include stdio.h#include stdio.hmain() float sn100.0,hnsn/2; int n; for(n2;n0) x1(x2+1)*2;/*第一天的桃子數(shù)是第2天桃子數(shù)加1后的2倍*/ x2x1; day-; printf(t
20、he total is %dn,x1); getch();【程序22】題目:兩個(gè)乒乓球隊(duì)進(jìn)行比賽,各出三人。甲隊(duì)為a,b,c三人,乙隊(duì)為x,y,z三人。已抽簽決定比賽名單。有人向隊(duì)員打聽比賽的名單。a說他不和x比,c說他不和x,z比,請(qǐng)編程序找出三隊(duì)賽手的名單。 1.程序分析:判斷素?cái)?shù)的方法:用一個(gè)數(shù)分別去除2到sqrt(這個(gè)數(shù)),如果能被整除,則表明此數(shù)不是素?cái)?shù),反之是素?cái)?shù)。 2.程序源代碼:#include stdio.h#include conio.hmain() char i,j,k;/*i是a的對(duì)手,j是b的對(duì)手,k是c的對(duì)手*/ for(ix;iz;i+) for(jx;jz;j+
21、) if(i!j) for(kx;kz;k+) if(i!k&j!k) if(i!x&k!x&k!z) printf(order is a-%ctb-%ctc-%cn,i,j,k); getch();【程序23】 題目:打印出如下圖案(菱形) * * * * * *1.程序分析:先把圖形分成兩部分來看待,前四行一個(gè)規(guī)律,后三行一個(gè)規(guī)律,利用雙重for循環(huán),第一層控制行,第二層控制列。 2.程序源代碼:#include stdio.h#include conio.hmain() int i,j,k; for(i0;i3;i+) for(j0;j2-i;j+) printf( ); for(k0;
22、k2*i;k+) printf(*); printf(n); for(i0;i2;i+) for(j0;ji;j+) printf( ); for(k0;k4-2*i;k+) printf(*); printf(n); getch();【程序24】 題目:有一分?jǐn)?shù)序列:2/1,3/2,5/3,8/5,13/8,21/13.求出這個(gè)數(shù)列的前20項(xiàng)之和。1.程序分析:請(qǐng)抓住分子與分母的變化規(guī)律。 2.程序源代碼:#include stdio.h#include conio.hmain() int n,t,number20; float a2,b1,s0; for(n1;nnumber;n+) ss
23、+a/b; ta;aa+b;bt;/*這部分是程序的關(guān)鍵,請(qǐng)讀者猜猜t的作用*/ printf(sum is %9.6fn,s); getch();【程序25】 題目:求1+2!+3!+.+20!的和1.程序分析:此程序只是把累加變成了累乘。 2.程序源代碼:#include stdio.h#include conio.hmain() float n,s0,t1; for(n1;n20;n+) t*n; s+t; printf(1+2!+3!.+20!%en,s); getch();【程序26】 題目:利用遞歸方法求5!。1.程序分析:遞歸公式:fnfn_1*4!2.程序源代碼:#includ
24、e stdio.h#include conio.hmain() int i; int fact(); for(i0;i5;i+) printf(40:%d!%dn,i,fact(i); getch();int fact(j)int j; int sum; if(j0) sum1; else sumj*fact(j-1); return sum;【程序27】 題目:利用遞歸函數(shù)調(diào)用方式,將所輸入的5個(gè)字符,以相反順序打印出來。1.程序分析:2.程序源代碼:#include stdio.h#include conio.hmain() int i5; void palin(int n); print
25、f(40:); palin(i); printf(n); getch();void palin(n)int n; char next; if(n1) nextgetchar(); printf(n0:); putchar(next); else nextgetchar(); palin(n-1); putchar(next); 【程序28】 題目:有5個(gè)人坐在一起,問第五個(gè)人多少歲?他說比第4個(gè)人大2歲。問第4個(gè)人歲數(shù),他說比第3個(gè)人大2歲。問第三個(gè)人,又說比第2人大兩歲。問第2個(gè)人,說比第一個(gè)人大兩歲。最后問第一個(gè)人,他說是10歲。請(qǐng)問第五個(gè)人多大?1.程序分析:利用遞歸的方法,遞歸分為回推
26、和遞推兩個(gè)階段。要想知道第五個(gè)人歲數(shù),需知道第四人的歲數(shù),依次類推,推到第一人(10歲),再往回推。2.程序源代碼:#include stdio.h#include conio.hage(n)int n; int c; if(n1) c10; else cage(n-1)+2; return(c);main() printf(%d,age(5); getch();【程序29】 題目:給一個(gè)不多于5位的正整數(shù),要求:一、求它是幾位數(shù),二、逆序打印出各位數(shù)字。1. 程序分析:學(xué)會(huì)分解出每一位數(shù),如下解釋:(這里是一種簡(jiǎn)單的算法,師專數(shù)002班趙鑫提供) 2.程序源代碼:#include stdio
27、.h#include conio.hmain( ) long a,b,c,d,e,x; scanf(%ld,&x); ax/10000;/*分解出萬位*/ bx%10000/1000;/*分解出千位*/ cx%1000/100;/*分解出百位*/ dx%100/10;/*分解出十位*/ ex%10;/*分解出個(gè)位*/ if (a!0) printf(there are 5, %ld %ld %ld %ld %ldn,e,d,c,b,a); else if (b!0) printf(there are 4, %ld %ld %ld %ldn,e,d,c,b); else if (c!0) pri
28、ntf( there are 3,%ld %ld %ldn,e,d,c); else if (d!0) printf(there are 2, %ld %ldn,e,d); else if (e!0) printf( there are 1,%ldn,e); getch();【程序30】 題目:一個(gè)5位數(shù),判斷它是不是回文數(shù)。即12321是回文數(shù),個(gè)位與萬位相同,十位與千位相同。1.程序分析:同29例2.程序源代碼:#include stdio.h#include conio.hmain( ) long ge,shi,qian,wan,x; scanf(%ld,&x); wanx/10000;
29、 qianx%10000/1000; shix%100/10; gex%10; if(gewan&shiqian)/*個(gè)位等于萬位并且十位等于千位*/ printf(this number is a huiwenn); else printf(this number is not a huiwenn); getch(); 【程序31】題目:請(qǐng)輸入星期幾的第一個(gè)字母來判斷一下是星期幾,如果第一個(gè)字母一樣,則繼續(xù)判斷第二個(gè)字母。1.程序分析:用情況語(yǔ)句比較好,如果第一個(gè)字母一樣,則判斷用情況語(yǔ)句或if語(yǔ)句判斷第二個(gè)字母。2.程序源代碼:#include stdio.h#include conio.
30、hvoid main() char letter; printf(please input the first letter of somedayn); while(lettergetch()!Y)/*當(dāng)所按字母為Y時(shí)才結(jié)束*/ switch (letter) case S:printf(please input second lettern); if(lettergetch()a) printf(saturdayn); else if (lettergetch()u) printf(sundayn); else printf(data errorn); break; case F:print
31、f(fridayn);break; case M:printf(mondayn);break; case T:printf(please input second lettern); if(lettergetch()u) printf(tuesdayn); else if (lettergetch()h) printf(thursdayn); else printf(data errorn); break; case W:printf(wednesdayn);break; default: printf(data errorn); getch();【程序32】題目:Press any key
32、to change color, do you want to try it. Please hurry up!1.程序分析:2.程序源代碼:#include conio.h#include stdio.hvoid main(void) int color; for (color 0; color 8; color+) textbackground(color);/*設(shè)置文本的背景顏色*/ cprintf(This is color %drn, color); cprintf(Press any key to continuern); getch();/*輸入字符看不見*/ 【程序33】題目:
33、學(xué)習(xí)gotoxy()與clrscr()函數(shù)1.程序分析:2.程序源代碼:#include conio.h#include stdio.hvoid main(void) clrscr();/*清屏函數(shù)*/ textbackground(2); gotoxy(1, 5);/*定位函數(shù)*/ cprintf(Output at row 5 column 1n); textbackground(3); gotoxy(20, 10); cprintf(Output at row 10 column 20n); getch();【程序34】題目:練習(xí)函數(shù)調(diào)用1. 程序分析: 2.程序源代碼:#include
34、 stdio.h#include conio.hvoid hello_world(void) printf(Hello, world!n);void three_hellos(void) int counter; for (counter 1; counter 3; counter+) hello_world();/*調(diào)用此函數(shù)*/void main(void) three_hellos();/*調(diào)用此函數(shù)*/ getch();【程序35】題目:文本顏色設(shè)置1.程序分析:2.程序源代碼:#include stdio.h#include conio.hvoid main(void) int co
35、lor; for (color 1; color 16; color+) textcolor(color);/*設(shè)置文本顏色*/ cprintf(This is color %drn, color); textcolor(128 + 15); cprintf(This is blinkingrn); getch();【程序36】題目:求100之內(nèi)的素?cái)?shù)1.程序分析:2.程序源代碼:#include stdio.h#include math.h#define N 101main() int i,j,line,aN; for(i2;iN;i+) aii; for(i2;isqrt(N);i+) f
36、or(ji+1;jN;j+) if(ai!0&aj!0) if(aj%ai0) aj0; printf(n); for(i2,line0;iN;i+) if(ai!0) printf(%5d,ai); line+; if(line10) printf(n); line0; getch();【程序37】題目:對(duì)10個(gè)數(shù)進(jìn)行排序1.程序分析:可以利用選擇法,即從后9個(gè)比較過程中,選擇一個(gè)最小的與第一個(gè)元素交換,下次類推,即用第二個(gè)元素與后8個(gè)進(jìn)行比較,并進(jìn)行交換。 2.程序源代碼:#include stdio.h#include conio.h#define N 10main() int i,j,
37、min,tem,aN; /*input data*/ printf(please input ten num:n); for(i0;iN;i+) printf(a%d,i); scanf(%d,&ai); printf(n); for(i0;iN;i+) printf(%5d,ai); printf(n); /*sort ten num*/ for(i0;iN-1;i+) mini; for(ji+1;jaj) minj; temai; aiamin; amintem; /*output data*/ printf(After sorted n); for(i0;iN;i+) printf(%
38、5d,ai); getch();【程序38】題目:求一個(gè)3*3矩陣對(duì)角線元素之和 1.程序分析:利用雙重for循環(huán)控制輸入二維數(shù)組,再將aii累加后輸出。2.程序源代碼:#include stdio.h#include conio.h/* 如果使用的是TC系列編譯器則可能需要添加下句 */static void dummyfloat(float *x) float y; dummyfloat(&y);main() float a33,sum0; int i,j; printf(please input rectangle element:n); for(i0;i3;i+) for(j0;j3;
39、j+) scanf(%f,&aij); for(i0;i3;i+) sumsum+aii; printf(duijiaoxian he is %6.2f,sum); getch();【程序39】題目:有一個(gè)已經(jīng)排好序的數(shù)組。現(xiàn)輸入一個(gè)數(shù),要求按原來的規(guī)律將它插入數(shù)組中。1. 程序分析:首先判斷此數(shù)是否大于最后一個(gè)數(shù),然后再考慮插入中間的數(shù)的情況,插入后此元素之后的數(shù),依次后移一個(gè)位置。 2.程序源代碼:#include stdio.h#include conio.hmain() int a111,4,6,9,13,16,19,28,40,100; int temp1,temp2,number,
40、end,i,j; printf(original array is:n); for(i0;iend) a10number; else for(i0;inumber) temp1ai; ainumber; for(ji+1;j11;j+) temp2aj; ajtemp1; temp1temp2; break; for(i0;i11;i+) printf(%6d,ai); getch();【程序40】題目:將一個(gè)數(shù)組逆序輸出。1.程序分析:用第一個(gè)與最后一個(gè)交換。2.程序源代碼:#include stdio.h#include conio.h#define N 5main() int aN9,6
41、,5,4,1,i,temp; printf(n original array:n); for(i0;iN;i+) printf(%4d,ai); for(i0;iN/2;i+) tempai; aiaN-i-1; aN-i-1temp; printf(n sorted array:n); for(i0;iN;i+) printf(%4d,ai); getch(); 【程序41】題目:學(xué)習(xí)static定義靜態(tài)變量的用法1.程序分析:2.程序源代碼:#include stdio.h#include conio.hvarfunc() int var0; static int static_var0;
42、 printf(40:var equal %d n,var); printf(40:static var equal %d n,static_var); printf(n); var+; static_var+;void main() int i; for(i0;i3;i+) varfunc(); getch();【程序42】 題目:學(xué)習(xí)使用auto定義變量的用法1.程序分析:2.程序源代碼:#include stdio.h#include conio.hmain() int i,num; num2; for(i0;i3;i+) printf(40: The num equal %d n,nu
43、m); num+; auto int num1; printf(40: The internal block num equal %d n,num); num+; getch();【程序43】題目:學(xué)習(xí)使用static的另一用法。1.程序分析:2.程序源代碼:#include stdio.h#include conio.hmain() int i,num; num2; for(i0;i3;i+) printf(40: The num equal %d n,num); num+; static int num1; printf(40:The internal block num equal %d
44、n,num); num+; getch();【程序44】題目:學(xué)習(xí)使用external的用法。1.程序分析:2.程序源代碼:#include stdio.h#include conio.hint a,b,c;void add() int a; a3; ca+b;void main() ab4; add(); printf(The value of c is equal to %dn,c); getch();【程序45】題目:學(xué)習(xí)使用register定義變量的方法。1.程序分析:2.程序源代碼:#include stdio.h#include conio.hvoid main() registe
45、r int i; int tmp0; for(i1;i); scanf(%d,&num); printf(40:The square for this number is %d n,SQ(num); if(num50) againTRUE; else againFALSE; getch();【程序47】題目:宏#define命令練習(xí)(2)1.程序分析:2.程序源代碼:#include stdio.h#include conio.h/*宏定義中允許包含兩道衣裳命令的情形,此時(shí)必須在最右邊加上*/#define exchange(a,b) int t; ta; ab; bt; void main(
46、void) int x10; int y20; printf(x%d; y%dn,x,y); exchange(x,y); printf(x%d; y%dn,x,y); getch();【程序48】題目:宏#define命令練習(xí)(3)1.程序分析:2.程序源代碼:#define LAG #define SMA y)?x:y#define MINIMUM(x,y) (xy)?y:xvoid main() int a10,b20;#ifdef MAX printf(40: The larger one is %dn,MAXIMUM(a,b);#else printf(40: The lower o
47、ne is %dn,MINIMUM(a,b);#endif#ifndef MIN printf(40: The lower one is %dn,MINIMUM(a,b);#else printf(40: The larger one is %dn,MAXIMUM(a,b);#endif#undef MAX#ifdef MAX printf(40: The larger one is %dn,MAXIMUM(a,b);#else printf(40: The lower one is %dn,MINIMUM(a,b);#endif#define MIN#ifndef MIN printf(40
48、: The lower one is %dn,MINIMUM(a,b);#else printf(40: The larger one is %dn,MAXIMUM(a,b);#endif getch();【程序50】題目:#include 的應(yīng)用練習(xí)1.程序分析:2.程序源代碼:test.h 文件如下:#define LAG #define SMA #define EQ 主文件如下:#include test.h /*一個(gè)新文件50.c,包含test.h*/#include stdio.h#include conio.hvoid main() int i10; int j20; if(i L
49、AG j) printf(40: %d larger than %d n,i,j); else if(i EQ j) printf(40: %d equal to %d n,i,j); else if(i SMA j) printf(40:%d smaller than %d n,i,j); else printf(40: No such value.n); getch(); 【程序51】題目:學(xué)習(xí)使用按位與 & 。1.程序分析:0&00; 0&10; 1&00; 1&112.程序源代碼:#include stdio.hmain()int a,b;a077;ba&3;printf(40: Th
50、e a & b(decimal) is %d n,b);b&7;printf(40: The a & b(decimal) is %d n,b);【程序52】題目:學(xué)習(xí)使用按位或 | 。1.程序分析:0|00; 0|11; 1|01; 1|112.程序源代碼:#include stdio.hmain()int a,b;a077;ba|3;printf(40: The a & b(decimal) is %d n,b);b|7;printf(40: The a & b(decimal) is %d n,b);【程序53】題目:學(xué)習(xí)使用按位異或 。1.程序分析:000; 011; 101; 110
51、2.程序源代碼:#include stdio.hmain()int a,b;a077;ba3;printf(40: The a & b(decimal) is %d n,b);b7;printf(40: The a & b(decimal) is %d n,b);【程序54】題目:取一個(gè)整數(shù)a從右端開始的47位。程序分析:可以這樣考慮: (1)先使a右移4位。(2)設(shè)置一個(gè)低4位全為1,其余全為0的數(shù)??捎?04;c(04);db&c;printf(%on%on,a,d);【程序55】題目:學(xué)習(xí)使用按位取反。1.程序分析:01; 10;2.程序源代碼:#include stdio.hmain(
52、)int a,b;a234;ba;printf(40: The as 1 complement(decimal) is %d n,b);aa;printf(40: The as 1 complement(hexidecimal) is %x n,a); 【程序56】題目:畫圖,學(xué)用circle畫圓形。1.程序分析:2.程序源代碼:/*circle*/#include graphics.hmain()int driver,mode,i;float j1,k1;driverVGA;modeVGAHI;initgraph(&driver,&mode,);setbkcolor(YELLOW);for(
53、i0;i25;i+)setcolor(8);circle(310,250,k);kk+j;jj+0.3; 【程序57】題目:畫圖,學(xué)用line畫直線。1.程序分析:2.程序源代碼:#include graphics.hmain()int driver,mode,i;float x0,y0,y1,x1;float j12,k;driverVGA;modeVGAHI;initgraph(&driver,&mode,);setbkcolor(GREEN);x0263;y0263;y1275;x1275;for(i0;i18;i+)setcolor(5);line(x0,y0,x0,y1);x0 x0
54、-5;y0y0-5;x1x1+5;y1y1+5;jj+10;x0263;y1275;y0263;for(i0;i20;i+)setcolor(5);line(x0,y0,x0,y1);x0 x0+5;y0y0+5;y1y1-5;【程序58】題目:畫圖,學(xué)用rectangle畫方形。1.程序分析:利用for循環(huán)控制100-999個(gè)數(shù),每個(gè)數(shù)分解出個(gè)位,十位,百位。2.程序源代碼:#include graphics.hmain()int x0,y0,y1,x1,driver,mode,i;driverVGA;modeVGAHI;initgraph(&driver,&mode,);setbkcolo
55、r(YELLOW);x0263;y0263;y1275;x1275;for(i0;i18;i+)setcolor(1);rectangle(x0,y0,x1,y1);x0 x0-5;y0y0-5;x1x1+5;y1y1+5;settextstyle(DEFAULT_FONT,HORIZ_DIR,2);outtextxy(150,40,How beautiful it is!);line(130,60,480,60);setcolor(2);circle(269,269,137);【程序59】題目:畫圖,綜合例子。1.程序分析:2.程序源代碼:# define PAI 3.1415926# de
56、fine B 0.809# include graphics.h#include math.hmain()int i,j,k,x0,y0,x,y,driver,mode;float a;driverCGA;modeCGAC0;initgraph(&driver,&mode,);setcolor(3);setbkcolor(GREEN);x0150;y0100;circle(x0,y0,10);circle(x0,y0,20);circle(x0,y0,50);for(i0;i16;i+)a(2*PAI/16)*i;xceil(x0+48*cos(a);yceil(y0+48*sin(a)*B)
57、;setcolor(2); line(x0,y0,x,y);setcolor(3);circle(x0,y0,60);/* Make 0 time normal size letters */settextstyle(DEFAULT_FONT,HORIZ_DIR,0);outtextxy(10,170,press a key);getch();setfillstyle(HATCH_FILL,YELLOW);floodfill(202,100,WHITE);getch();for(k0;k500;k+)setcolor(3);for(i0;i16;i+)a(2*PAI/16)*i+(2*PAI/
58、180)*k;xceil(x0+48*cos(a);yceil(y0+48+sin(a)*B);setcolor(2); line(x0,y0,x,y);for(j1;j50;j+)a(2*PAI/16)*i+(2*PAI/180)*k-1;xceil(x0+48*cos(a);yceil(y0+48*sin(a)*B);line(x0,y0,x,y);restorecrtmode();【程序60】題目:畫圖,綜合例子。1.程序分析:2.程序源代碼:#include graphics.h#define LEFT 0#define TOP 0#define RIGHT 639#define BO
59、TTOM 479#define LINES 400#define MAXCOLOR 15main()int driver,mode,error;int x1,y1;int x2,y2;int dx1,dy1,dx2,dy2,i1;int count0;int color0;driverVGA;modeVGAHI;initgraph(&driver,&mode,);x1x2y1y210;dx1dy12;dx2dy23;while(!kbhit()line(x1,y1,x2,y2);x1+dx1;y1+dy1;x2+dx2;y2+dy2;if(x1RIGHT)dx1-dx1;if(y1BOTTOM
60、)dy1-dy1;if(x2RIGHT)dx2-dx2;if(y2BOTTOM)dy2-dy2;if(+countLINES)setcolor(color);color(colorMAXCOLOR)?0:+color;closegraph();【程序61】題目:打印出楊輝三角形(要求打印出10行如下圖)1.程序分析: 11 11 2 11 3 3 11 4 6 4 11 5 10105 1 2.程序源代碼:main()int i,j;int a1010;printf(n);for(i0;i10;i+)ai01;aii1;for(i2;i10;i+)for(j1;ji;j+)aijai-1j-1
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度直播平臺(tái)主播培訓(xùn)及管理合同
- 2025年度新能源汽車產(chǎn)業(yè)投資合作合同
- 二零二五年度商標(biāo)共營(yíng)協(xié)議及跨國(guó)品牌合作合同
- 二零二五年度超市商品陳列與文化氛圍營(yíng)造合同
- 2025年度民宿租賃合同終止及服務(wù)質(zhì)量協(xié)議
- 二零二五年度集體合同簽訂與新型學(xué)徒制實(shí)施
- 二零二五年度個(gè)人對(duì)個(gè)人科技成果轉(zhuǎn)化借款合同
- 2025年度機(jī)關(guān)炊事員食品安全培訓(xùn)聘用協(xié)議
- 日常行政管理事務(wù)處理指導(dǎo)書
- 日化用品行業(yè)供應(yīng)鏈優(yōu)化與市場(chǎng)拓展策略研究計(jì)劃
- 材料化學(xué)合成與制備技術(shù)
- 金屬工藝學(xué)(鑄造)課件
- DB23∕T 343-2003 國(guó)有林區(qū)更新造林技術(shù)規(guī)程
- 醫(yī)療廢物管理組織機(jī)構(gòu)架構(gòu)圖
- cjj/t135-2009《透水水泥混凝土路面技術(shù)規(guī)程》
- 短時(shí)耐受電流
- 社保人事專員績(jī)效考核表
- 河北省自然科學(xué)基金資助項(xiàng)目申請(qǐng)書模板
- 上海世博會(huì)對(duì)上海城市競(jìng)爭(zhēng)力影響的評(píng)估模型
- 河南書法家協(xié)會(huì)入會(huì)申請(qǐng)表
- 鄉(xiāng)村獸醫(yī)登記申請(qǐng)表(共1頁(yè))
評(píng)論
0/150
提交評(píng)論