版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
3.1函數(shù)3.2變量的作用域3.3
算法基本概念和典型實(shí)例3.4C語(yǔ)言預(yù)處理器3.5C程序的典型結(jié)構(gòu)3.6
正確使用庫(kù)函數(shù)3.7
錯(cuò)誤分析第3章函數(shù)與變量類型主要內(nèi)容3.1函數(shù)函數(shù)概述函數(shù)的定義函數(shù)的調(diào)用函數(shù)值函數(shù)聲明函數(shù)的參數(shù)(形參、實(shí)參)逐步分解,分而治之,模塊化程序設(shè)計(jì)方法!C程序由一個(gè)主函數(shù)main()和若干其它函數(shù)組成。主函數(shù)main():執(zhí)行過程開始,執(zhí)行結(jié)束處。主調(diào)函數(shù)與被調(diào)函數(shù):調(diào)用其它函數(shù)的函數(shù)稱為主調(diào)函數(shù);被其它函數(shù)調(diào)用的函數(shù)稱為被調(diào)函數(shù).main()函數(shù)只能是主調(diào)函數(shù),其他函數(shù)之間可相互調(diào)用。例利用函數(shù)實(shí)現(xiàn)信息打印。#include<stdio.h>voidprint_space(){printf("\n");}voidprint_message(){printf("\nWelcomeyoutouseClanguage!");
print_space();}voidmain(){print_message();
print_space();}例3.1函數(shù)的定義與調(diào)用函數(shù)定義:1、函數(shù)頭2、函數(shù)體空函數(shù)函數(shù)的定義無(wú)參函數(shù)的一般形式函數(shù)類型函數(shù)名(void){說明語(yǔ)句部分;可執(zhí)行語(yǔ)句部分;
}有參函數(shù)的一般形式函數(shù)類型函數(shù)名(數(shù)據(jù)類型參數(shù)[,數(shù)據(jù)類型參數(shù)2……]){說明語(yǔ)句部分;可執(zhí)行語(yǔ)句部分;
}例#include<stdio.h>intmax(inta,intb){ intc; if(a>b)c=a; elsec=b; returnc;}voidmain(){ intx,y,z; printf("inputx,y:"); scanf("%d%d",&x,&y);z=max(x,y); printf("max=%d\n",z);}int
max(int
x,inty){
intt;t=x>y?x:y;returnt;}函數(shù)值與return語(yǔ)句函數(shù)的返回值是通過函數(shù)調(diào)用使主調(diào)函數(shù)得到的確定值return;return(表達(dá)式);作用:1、使程序立即從當(dāng)前運(yùn)行的函數(shù)中返回調(diào)用處,繼續(xù)執(zhí)行主調(diào)函數(shù)的代碼。2、在函數(shù)要求有一個(gè)返回值的情況下,將其后表達(dá)式的值返回給主調(diào)函數(shù)。例
編寫函數(shù)輸出一個(gè)n行的三角形圖形.#include<stdio.h>voidprint(intn){for(inti=1;i<=n;i++){for(intj=1;j<=n-i;j++)putchar('');for(j=1;j<=2*i-1;j++)putchar('*');putchar('\n');}return;}voidmain(){ print(5);}函數(shù)的特點(diǎn):1、函數(shù)具有相對(duì)獨(dú)立的功能.不能嵌套定義.2、函數(shù)與函數(shù)之間通過參數(shù)和返回值來(lái)聯(lián)系3、使用函數(shù)有利于代碼重用,提高開發(fā)效率,增強(qiáng)程序的可靠性,便于修改維護(hù)。函數(shù)的調(diào)用1、函數(shù)的聲明2、函數(shù)的調(diào)用調(diào)用形式:函數(shù)語(yǔ)句例3.2
例3.3函數(shù)表達(dá)式x=max(a,b)函數(shù)參數(shù)調(diào)用例3.4函數(shù)的調(diào)用參數(shù)傳遞機(jī)制形參和實(shí)參函數(shù)的調(diào)用格式:函數(shù)名(實(shí)參表)
max(x,y)實(shí)參與形參必須個(gè)數(shù)相同、類型一致!例
計(jì)算階乘.#include<stdio.h>voidmain(){
intn;longfactor(int);
printf("pleaseinputanintegern=");
scanf("%d",&n);while(n>=0){
printf("%d!=%ld",n,factor(n));
printf("\npleaseinputanintegeragainn=");
scanf("%d",&n);}
printf("negativenumberillegal!\n");}longfactor(intm){
inti;longfa;fa=1;for(i=1;i<=m;i++)
fa=fa*i;return(fa);}3.2變量作用域作用域:作用范圍,有效的范圍。局部變量(內(nèi)部變量)全局變量(外部變量)存儲(chǔ)方式:在內(nèi)存中的存儲(chǔ)方式(auto、static、register、extern)靜態(tài)存儲(chǔ)動(dòng)態(tài)存儲(chǔ)變量的作用域變量的有效范圍稱為變量的作用域。按作用域分為兩種:局部變量:在一個(gè)函數(shù)內(nèi)部聲明的變量。其作用域只在本函數(shù)范圍內(nèi)。全局變量:在文件作用域中聲明的變量。作用域從生命該變量的語(yǔ)句位置開始,直至本文件結(jié)束。例3.5演示程序塊、外部變量、自動(dòng)型變量任何以花括號(hào)括起來(lái)的復(fù)合語(yǔ)句都屬于塊結(jié)構(gòu)例
局部變量的使用#include<stdio.h>voidf1(){inta=3,b=2;a*=b;b/=2;
printf("a=%d,b=%d\n",a,b);}voidmain(){inta=4,b=3;f1();
printf("a=%d,b=%d\n",a,b);}主函數(shù)main()中的a,b和f1()中的a,b是不同的內(nèi)容!函數(shù)獨(dú)立!局部變量使用說明:在不同函數(shù)中可聲明具有相同變量名的局部變量。形參也是局部變量,作用域在定義它的函數(shù)內(nèi)。形參和該函數(shù)體內(nèi)的變量是不能重名的。全局變量的使用#include<stdio.h>int
a,b;voidf1(){intt1,t2;t1=a*2;t2=b*3;b=100;printf("t1=%d,t2=%d\n",t1,t2);}voidmain(){a=2;b=4;f1();
printf("a=%d,b=%d\n",a,b);}t1=4,t2=12a=2,b=100
例3.6全局變量使用說明1、全局變量的作用域是從聲明處開始到程序結(jié)束。2、全局變量的作用域?yàn)楹瘮?shù)間傳遞數(shù)據(jù)提供了一種新的方法。3、在一個(gè)函數(shù)內(nèi)部,一個(gè)局部變量和一個(gè)全局變量重名時(shí),全局變量不起作用。4、建議少使用全局變量。建議:不必要時(shí)不要使用全局變量,原因如下:
1、全局變量在程序的全部執(zhí)行過程中都占用存儲(chǔ)單元,而不是僅在需要時(shí)才開辟單元。2、使用全局變量過多,會(huì)降低程序的清晰性。在各個(gè)函數(shù)執(zhí)行時(shí)都可能改變外部變量的值,程序容易出錯(cuò)。因此,要限制使用全局變量。3、使用全局變量過多,會(huì)降低函數(shù)的通用性。變量的存儲(chǔ)方式靜態(tài)存儲(chǔ)區(qū):變量在運(yùn)行過程中占據(jù)固定的存儲(chǔ)空間。數(shù)據(jù)段動(dòng)態(tài)存儲(chǔ)區(qū):存放變量及進(jìn)行函數(shù)調(diào)用時(shí)的現(xiàn)場(chǎng)信息和函數(shù)返回地址等。棧段變量分為靜態(tài)存儲(chǔ)變量和動(dòng)態(tài)存儲(chǔ)變量。動(dòng)態(tài)存儲(chǔ)變量:使用時(shí)分配存儲(chǔ)單元,使用完畢立即釋放靜態(tài)存儲(chǔ)變量:分配存儲(chǔ)單元一直保持不變,直至程序結(jié)束。四種存儲(chǔ)類型:自動(dòng)變量(auto)靜態(tài)變量(static)寄存器變量(register)外部變量(extern)局部變量的存儲(chǔ)方式自動(dòng)變量(auto):默認(rèn)方式。靜態(tài)局部變量(static):分配在靜態(tài)存儲(chǔ)區(qū),在函數(shù)調(diào)用結(jié)束后,其所占內(nèi)存空間也不被釋放,靜態(tài)變量仍然保持它的值。寄存器變量(register):存放在CPU內(nèi)部寄存器中,提高運(yùn)行效率。數(shù)量受限。例
靜態(tài)局部變量說明。#include<stdio.h>voidf(){autointj=0;++j;
printf("%d\n",j);}voidmain(){inti;f();for(i=1;i<=3;i++) f();}輸出1111例
靜態(tài)局部變量說明。#include<stdio.h>voidf(){staticintj=0;++j;
printf("%d\n",j);}voidmain(){inti;f();for(i=1;i<=3;i++) f();}輸出1234例靜態(tài)局部變量說明。#include<iostream.h>int
f(inta){autointb=0;staticintc=3;b++;c++;
return(a+b+c);}
voidmain(){
inta=2,i; for(i=0;i<3;i++)
cout<<f(a)<<endl;}輸出7893.3算法基本概念和典型實(shí)例1、算法基本概念2、迭代算法3、遞推算法4、遞歸算法算法基本概念廣義地說,為解決一個(gè)問題而采取的方法和步驟,就稱為“算法”。為了有效地進(jìn)行解題,不僅需要保證算法正確,還要考慮算法的質(zhì)量,選擇合適的算法。希望方法簡(jiǎn)單,運(yùn)算步驟少。計(jì)算機(jī)算法可分為兩大類別:數(shù)值運(yùn)算算法:求數(shù)值解,例如求方程的根、求函數(shù)的定積分等。非數(shù)值運(yùn)算:包括的面十分廣泛,最常見的是用于事務(wù)管理領(lǐng)域,例如圖書檢索、人事管理、行車調(diào)度管理等。算法的特征有限性:包含有限的操作步驟。確定性:算法中的每一個(gè)步驟都應(yīng)當(dāng)是確定的。有零個(gè)或多個(gè)輸入:輸入是指在執(zhí)行算法時(shí)需要從外界取得必要的信息。有一個(gè)或多個(gè)輸出:算法的目的是為了求解,“解”就是輸出。可行性:算法中的每一個(gè)步驟都應(yīng)當(dāng)能有效地執(zhí)行,并得到確定的結(jié)果。一個(gè)算法應(yīng)該具有以下特點(diǎn):算法效率和算法分析兩個(gè)目標(biāo):1、設(shè)計(jì)一個(gè)正確的、容易理解、容易編碼和調(diào)試的算法2、設(shè)計(jì)一個(gè)能有效利用計(jì)算機(jī)資源和求解效率高的算法。時(shí)間復(fù)雜度:執(zhí)行算法所耗費(fèi)的時(shí)間空間復(fù)雜度:執(zhí)行算法所使用的存儲(chǔ)空間算法的重要性!著名計(jì)算機(jī)科學(xué)家沃思提出一個(gè)公式:
數(shù)據(jù)結(jié)構(gòu)+算法=程序
數(shù)據(jù)結(jié)構(gòu)+算法+程序設(shè)計(jì)方法+語(yǔ)言工具完整的程序設(shè)計(jì)包括:迭代算法通過重復(fù)執(zhí)行一系列計(jì)算來(lái)獲得問題的近似答案,而每一次重復(fù)計(jì)算將產(chǎn)生一個(gè)更精確一些的答案。圓周率π的近似計(jì)算:π/4=1-1/3+1/5-1/7+……正弦函數(shù)的值的計(jì)算:例3.7遞推算法將復(fù)雜的運(yùn)算轉(zhuǎn)化為簡(jiǎn)單運(yùn)算的重復(fù)。1、遞推數(shù)列:從某一項(xiàng)開始,任何一項(xiàng)都可以用它前面的若干項(xiàng)來(lái)確定。
n!計(jì)算:fact(n)=n*fact(n-1)fact(1)=12、遞推算法的程序?qū)崿F(xiàn):
例3.8狗熊吃玉米
例3.9分魚游戲遞歸算法遞推過程相當(dāng)于從菜心“推到”外層。遞歸算法,從所求的未知項(xiàng)出發(fā)逐次調(diào)用本身,直到遞歸的邊界(初始條件)例3.10求5的階乘值(遞推)例3.11求階乘的遞歸調(diào)用程序編譯預(yù)處理是指,在對(duì)源程序進(jìn)行編譯之前,先對(duì)源程序中的編譯預(yù)處理命令進(jìn)行處理;然后再將處理的結(jié)果,和源程序一起進(jìn)行編譯,以得到目標(biāo)代碼。3.4C語(yǔ)言預(yù)處理器宏定義文件包含條件編譯概念在C源程序中加入一些“預(yù)處理命令”
,以改進(jìn)程序設(shè)計(jì)環(huán)境,提高編程效率。C語(yǔ)言與其他高級(jí)語(yǔ)言的一個(gè)重要區(qū)別是可以使用預(yù)處理命令和具有預(yù)處理的功能。預(yù)處理命令不是C語(yǔ)言本身的組成部分,不能直接對(duì)它們進(jìn)行編譯(因?yàn)榫幾g程序不能識(shí)別它們)。必須在對(duì)程序進(jìn)行通常的編譯之前,先對(duì)程序中這些特殊的命令進(jìn)行“預(yù)處理”。經(jīng)過預(yù)處理后程序可由編譯程序?qū)︻A(yù)處理后的源程序進(jìn)行通常的編譯處理,得到可供執(zhí)行的目標(biāo)代碼。C提供的預(yù)處理功能主要有以下三種:
1.宏定義2.文件包含3.條件編譯
這些功能分別用宏定義命令、文件包含命令、條件編譯命令來(lái)實(shí)現(xiàn)。為了與一般C語(yǔ)句相區(qū)別,這些命令以符號(hào)“?!遍_頭。例如:
#define#include宏定義與const修飾符不帶參數(shù)的宏定義宏定義一般形式為:#define
標(biāo)識(shí)符字符串例如:#definePI3.1415926宏定義的作用是在本程序文件中用指定的標(biāo)識(shí)符PI來(lái)代替“3.1415926”這個(gè)字符串,在編譯預(yù)處理時(shí),將程序中在該命令以后出現(xiàn)的所有的PI都用“3.1415926”代替。這個(gè)標(biāo)識(shí)符(名字)稱為“宏名”。在預(yù)編譯時(shí)將宏名替換成字符串的過程稱為“宏展開”。#define是宏定義命令。#define
MAXSIZE
100constintMAXSIZE=100例
使用不帶參數(shù)的宏定義。
#include<stdio.h>#definePI3.1415926voidmain(){floatl,s,r,v;
printf("inputradius:");
scanf("%f",&r);l=2.0*PI*r;s=PI*r*r;v=4.0/3*PI*r*r*r;printf("l=%10.4f\ns=%10.4f\nv=%10.4f\n",l,s,v);}使用宏定義的優(yōu)點(diǎn)(1)可提高源程序的可維護(hù)性(2)可提高源程序的可移植性(3)減少源程序中重復(fù)書寫字符串的工作量帶參數(shù)的宏定義
作用:不是進(jìn)行簡(jiǎn)單的字符串替換,還要進(jìn)行參數(shù)替換。
帶參數(shù)的宏定義一般形式為:#define
宏名(參數(shù)表)字符串字符串中包含在括弧中所指定的參數(shù)#define
S(a,b)a*b
area=S(3,2);#defineMAX(a,b)((a)>(b)?(a):(b)x=MAX(p+q,r+s)例:運(yùn)行情況如下:r=3.600000area=40.715038例
使用帶參的宏
賦值語(yǔ)句“area=S(a);
”經(jīng)宏展開后為:area=3.1415926*a*a;
#include<stdio.h>#definePI3.1415926#defineS(r)PI*r*rvoidmain(){floata,area;a=3.6;area=S(a);
printf("r=%f\narea=%f\n",a,area);}所謂“文件包含”處理是指一個(gè)源文件可以將另外一個(gè)源文件的全部?jī)?nèi)容包含進(jìn)來(lái)。C語(yǔ)言提供了#include命令用來(lái)實(shí)現(xiàn)“文件包含”的操作。其一般形式為:#include"文件名"或#include<文件名>
文件包含(1)一個(gè)#include命令只能指定一個(gè)被包含文件,如果要包含n個(gè)文件,要用n個(gè)#include命令。(2)如果文件1包含文件2,而在文件2中要用到文件3的內(nèi)容,則可在文件1中用兩個(gè)include命令分別包含文件2和文件3,而且文件3應(yīng)出現(xiàn)在文件2之前,即在file1.c中定義。(3)在一個(gè)被包含文件中又可以包含另一個(gè)被包含文件,即文件包含是可以嵌套的。(4)在#include命令中,文件名可以用雙撇號(hào)或尖括號(hào)括起來(lái)。(5)被包含文件(file2.h)與其所在的文件,在預(yù)編譯后已成為同一個(gè)文件(而不是兩個(gè)文件)。說明:“”<>兩種格式的區(qū)別僅在于:(1)使用雙引號(hào):系統(tǒng)首先到當(dāng)前目錄下查找被包含文件,如果沒找到,再到系統(tǒng)指定的“包含文件目錄”(由用戶在配置環(huán)境時(shí)設(shè)置)去查找。(2)使用尖括號(hào):直接到系統(tǒng)指定的“包含文件目錄”去查找。一般地說,使用雙引號(hào)比較保險(xiǎn)。文件包含的優(yōu)點(diǎn):一個(gè)大程序,通常分為多個(gè)模塊,并由多個(gè)程序員分別編程。有了文件包含處理功能,就可以將多個(gè)模塊共用的數(shù)據(jù)(如符號(hào)常量和數(shù)據(jù)結(jié)構(gòu))或函數(shù),集中到一個(gè)單獨(dú)的文件中。這樣,凡是要使用其中數(shù)據(jù)或調(diào)用其中函數(shù)的程序員,只要使用文件包含處理功能,將所需文件包含進(jìn)來(lái)即可,不必再重復(fù)定義它們,從而減少重復(fù)勞動(dòng)。
條件編譯概念:所謂“條件編譯”,是對(duì)部分內(nèi)容指定編譯的條件,使其只在滿足一定條件才進(jìn)行編譯。條件編譯命令的幾種形式:(1)#ifdef
標(biāo)識(shí)符程序段1#else
程序段2#endif(2)#ifndef
標(biāo)識(shí)符程序段1#else
程序段2#endif(3)#if表達(dá)式程序段1#else
程序段2#endif例輸入一行字母字符,根據(jù)需要設(shè)置條件編譯,使之能將字母全改為大寫輸出,或全改為小寫字母輸出。運(yùn)行結(jié)果為:CLANGUAGE#include<stdio.h>#defineLETTER1voidmain(){charstr[20]="CLanguage",c;
inti;i=0;
while((c=str[i])!='\0'){i++;#ifLETTERif(c>='a'&&c<='z')c=c-32;#elseif(c>='A'&&c<='Z')c=c+32;#endif
printf("%c",c);}}
條件編譯可有效地提高程序的可移植性,并廣泛地應(yīng)用在商業(yè)軟件中,為一個(gè)程序提供各種不同的版本。
3.5C程序的典型結(jié)構(gòu)1、單文件結(jié)構(gòu)例3.122、一個(gè)源文件和一個(gè)頭文件改造3.123、多文件結(jié)構(gòu)一個(gè)源文件和一個(gè)頭文件頭文件:用來(lái)編寫預(yù)處理命令、函數(shù)原型聲明及全局變量聲明或定義。源文件:包含頭文件、編寫相應(yīng)主程序和函數(shù)多文件結(jié)構(gòu)1、使用多個(gè)文件進(jìn)行模塊化設(shè)計(jì)1002、頭文件和函數(shù)原型的作用3、組合為一個(gè)工程項(xiàng)目4、#define和const的異同5、使用條件編譯編寫頭文件6、使用文件包含的方法7、一般的多文件模式3.6正確使用庫(kù)函數(shù)錯(cuò)例3.1忘記添加頭文件錯(cuò)例3.2調(diào)用方式不對(duì),角度變弧度錯(cuò)例3.3缺少頭文件,調(diào)用方式不對(duì)3.7錯(cuò)誤分析錯(cuò)例3.4錯(cuò)例3.5錯(cuò)例3.6錯(cuò)例3.7Page97~99例3.1#include<stdio.h>doublemax(double,double);intmain(){doublea,b,x;a=2.5;b=3.5;
x=max(a,b);printf("%f\n",x);return0;}doublemax(doublem,doublen){doublex;if(m>n)x=m;elsex=n;returnx;}例3.2#include<stdio.h>voidroom1();voidroom2();voidmain(){printf("Iaminmainandcallroom.\n");room1();room2();}voidroom1(){printf("NowIaminroom1.\n");}voidroom2(){printf("NowIaminroom2.\n");}例3.3#include<stdio.h>voidroom1();voidroom2();voidmain(){printf("Iaminmainandcallroom.\n");room1();}voidroom2(){printf("NowIaminroom2.\n");}voidroom1(){printf("NowIaminroom1andcallroom2.\n");room2();}例3.4#include<stdio.h>doublemax(double,double);voidmain(){doublea=2.5,b=3.39,c=13.25;printf("max=%f\n",max(c,max(a,b)));}doublemax(doublem,doublen){if(m>n)returnm;elsereturnn;}例3.5#include<iostream.h>#include<stdio.h>intx=4,y=5;voidmain(){{intx=1;{intx=2;{intx=3;printf("x=%d,&x=%u\n",x,&x);printf("y=%d,&y=%u\n",y,&y);}printf("x=%d,&x=%u\n",x,&x);printf("y=%d,&y=%u\n",y,&y);}printf("x=%d,&x=%u\n",x,&x);printf("y=%d,&y=%u\n",y,&y);}printf("x=%d,&x=%u\n",x,&x);printf("y=%d,&y=%u\n",y,&y);}例3.6#include<stdio.h>intx=123;voidmain(){externy;printf("x=%d,y=%d\n",x,y);}inty=321;例3.7#include<stdio.h>#include<math.h>voidmain(){doublex,sinx,item,min=0.0005;intn=1,sign=-1;printf("輸入度數(shù):");scanf("%lf",&x);while(x>360) x=x-360;x=x*3.14159/180;sinx=x;item=x;while(fabs(item)>min){item=item*x*x/(n+1)/(n+2);sinx=sinx+sign*item;n=n+2;sign=(-1)*sign;}printf("sinx=%lf\n",sinx);}例3.8#include<stdio.h>voidmain(){intday=9,x=1;while(day>0){x=(x+1)*2;day--;}printf("玉米棒總數(shù)=%d\n",x);}例3.9#include<stdio.h>voidmain(){intfish[6]={1,1,1,1,1,1};inti=0;do{fish[5]=fish[5]+5;for(i=4;i>=1;i--){if(fish[i+1]%4!=0)break;else fish[i]=fish[i+1]*5/4+1;}}while(i>=1);for(i=1;i<=5;i++) printf("第%d個(gè)人看到的魚是%d條。\n",i,fish[i]);}例3.10#include<stdio.h>voidmain(){intsum=1,i=0;for(i=2;i<=5;i++) sum=i*sum; printf("5!=%d\n",sum);}例3.11#include<stdio.h>intfactorial(int);voidmain(){intn;printf("inputn=");scanf("%d",&n);printf("%d!=%d\n",n,factorial(n));}intfactorial(intx){if(x==0)return1;elsereturn(x*factorial(x-1));}例3.12#include<stdio.h>#defineNUM100intmax(int,int);intmain(){inta,b,x;a=2,b=3;x=NUM*max(a,b);printf("%d\n",x);return0;}intmax(intm1,intm2){if(m1>m2)returnm1+NUM;elsereturnm2+NUM;}例3.12改為一個(gè)源文件和一個(gè)頭文件#include“c6.h”intmain(){inta,b,x;a=2,b=3;x=NUM*max(a,b);printf("%d\n",x);return0;}intmax(intm1,intm2){if(m1>m2)returnm1+NUM;elsereturnm2+NUM;}c6.h#include<stdio.h>#defineNUM100intmax(int,int);max.cdoublemax(doublem1,doublem2){if(m1>m2)returnm1;elsereturnm2;}find.c#include"find.h"voidmain(){doublea,b;printf("Inputaandb:\n");scanf("%lf%lf",&a,&b);printf("max=%lf\n",max(a,b));printf("mean=%lf\n",mean(a,b));}find.h#include<stdio.h>doublemax(double,double);doublemean(double,double);mean.hconstdoubleDIV2=0.5;mean.c#include"mean.h"doublemean(doublem1,doublem2){return((m2+m1)*DIV2);}
max.cexternintn;doublemax(doublem1,doublem2){n++;if(m1>m2)returnm1;elsereturnm2;}
f.c#include"f.h"constdoubleK=2;voidmain(){doublea,b;printf("Inputaandb:\n");scanf("%lf%lf",&a,&b);printf("max=%lf\n",max(a,b));printf("min=%lf\n",min(a,b));printf("mean=%lf\n",mean(a,b));printf("2*mean=%lf\n",K*mean(a,b));printf("n=%d\n",n);}
f.h#include"stdio.h"externconstdoubleK;externintn=0;doublemax(double,double);doublemean(double,double);doublemin(double,double);
min.cexternintn;doublemin(doublem1,doublem2){n++; if(m1>m2)returnm2;elsereturnm1;}
mean.cexternintn;doublemean(doublem1,doublem2){n++;return((m2+m1)/2);}實(shí)訓(xùn)3format.h#defineDIGIT(d)printf("整數(shù)輸出:%d\n",d);#defineFLOAT(f)printf("實(shí)數(shù)輸出:%10.2f\n",f);#defineSTRING(s)printf("字符串輸出:%s\n",s);分析題(2)f.c#include<stdio.h>#include"format.h"voidmain(){intd,num;floatf;chars[80];printf("請(qǐng)選擇輸入形式1-整數(shù),2-實(shí)數(shù),3-字符串:");scanf("%d",&num);switch(num){case1:printf("請(qǐng)輸入一個(gè)整數(shù):");scanf("%d",&d);DIGIT(d);break;case2:printf("請(qǐng)輸入一個(gè)實(shí)數(shù):");scanf("%f",&f);FLOAT(f);break;case3:printf("請(qǐng)輸入一個(gè)字符串:");scanf("%s",s);STRING(s);break;default:printf("輸入錯(cuò)誤!");}}分析題(2)intfac(intn){staticintf=1;intf=1;inti=1;for(i=1;i<=n;i++)f=f*i;return(f);}#include<stdio.h>intfac(int);voidmain(){inti;for(i=1;i<=4;i++)printf("%d!=%d\n",i,fac(i));}分析題(3)#include<stdio.h>voidmain(){intx;/*不確定值*/staticinty;/*0*/staticintz=5;/*5*/printf("x=%d,y=%d,z=%d\n",x,y,z);}分析題(4)#include<stdio.h>voidconvert(intn){inti;if((i=n/10)!=0)convert(i);putchar(n%10+'0');}voidmain(){intnumber;scanf("%d",&number);if(number<0){putchar('-');number=-number;}convert(number);}習(xí)題選解(1)#include<stdio.h>#defineSWAP(a,b)t=b;b=a;a=tvoidmain(){inta,b,t;scanf("%d,%d",&a,&b);SWAP(a,b);printf("a=%d\tb=%d\n",a,b);}
習(xí)題選解(2)#defineMAX(a,b)((a)>(b)?(a):(b))#include<stdio.h>voidmain(){inta,b,c;scanf("%d,%d,%d",&a,&b,&c);printf("max=%d\n",MAX(MAX(a,b),c));}習(xí)題選解(3)#include"stdio.h"#defineMAX80#defineCHA
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 文藝復(fù)興時(shí)期教育體系發(fā)展
- xx學(xué)校對(duì)供應(yīng)商考核評(píng)價(jià)制度
- 設(shè)備維護(hù)健康檔案管理制度
- 醫(yī)院藥品管理與監(jiān)督制度
- 企業(yè)員工績(jī)效考核與激勵(lì)制度匯編
- 智能制造項(xiàng)目風(fēng)險(xiǎn)管理實(shí)踐
- 公務(wù)員考試邏輯推理真題解析
- 化肥倉(cāng)儲(chǔ)及運(yùn)輸安全管理措施
- 中學(xué)作文寫作技巧與范文集
- 耐心資本助力企業(yè)高質(zhì)量發(fā)展
- 蘇教版六年級(jí)數(shù)學(xué)上冊(cè)全冊(cè)知識(shí)點(diǎn)歸納(全梳理)
- 2025年版?zhèn)€人與公司居間合同范例
- 中鐵物資采購(gòu)?fù)稑?biāo)
- 泄漏管理培訓(xùn)課件
- 電子商務(wù)平臺(tái)項(xiàng)目運(yùn)營(yíng)合作協(xié)議書范本
- 動(dòng)設(shè)備監(jiān)測(cè)課件 振動(dòng)狀態(tài)監(jiān)測(cè)技術(shù)基礎(chǔ)知識(shí)
- 服裝廠員工績(jī)效考核與獎(jiǎng)懲制度
- 專題15平面解析幾何(選擇填空題)(第一部分)(解析版) - 大數(shù)據(jù)之十年高考真題(2014-2025)與優(yōu) 質(zhì)模擬題(新高考卷與全國(guó)理科卷)
- 部門考核方案
- 茜草素的藥代動(dòng)力學(xué)和藥效學(xué)研究
- T-CPQS C010-2024 鑒賞收藏用潮流玩偶及類似用途產(chǎn)品
評(píng)論
0/150
提交評(píng)論