C++程序設(shè)計(譚浩強完整版).ppt_第1頁
C++程序設(shè)計(譚浩強完整版).ppt_第2頁
C++程序設(shè)計(譚浩強完整版).ppt_第3頁
C++程序設(shè)計(譚浩強完整版).ppt_第4頁
C++程序設(shè)計(譚浩強完整版).ppt_第5頁
已閱讀5頁,還剩925頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、1,C+程序設(shè)計 譚浩強編著 清華大學(xué)出版社 課件制作:南京理工大學(xué) 陳清華 朱紅,2,第一章C+概述,C+語言發(fā)展歷史,自從1946年第一臺電子數(shù)字計算機ENIAC問世以來,隨著計算機應(yīng)用領(lǐng)域的不斷擴大,促進(jìn)了計算機技術(shù)的高速發(fā)展,尤其是近年來計算機的硬件和軟件都是日新月異。作為應(yīng)用計算機的一種工具程序設(shè)計語言,得到不斷的充實和完善。每年都有新的程序設(shè)計語言問世,老的程序設(shè)計語言不斷地更新?lián)Q代,3,20世紀(jì)60年代,Martin Richards為計算機軟件人員在開發(fā)系統(tǒng)軟件時,作為記述語言使用而開發(fā)了BCPL語言(Basic Combined Programming Language)。1

2、970年,Ken Thompson在繼承BCPL語言的許多優(yōu)點的基礎(chǔ)上發(fā)明了實用的B語言。到了1972年,貝爾實驗室的Dennis Ritchie和Brian kernighan在B語言的基礎(chǔ)上,作了進(jìn)一步的充實和完善,設(shè)計出了C語言。當(dāng)時,設(shè)計C語言是為了編寫UNIX操作系統(tǒng)的。以后,C語言經(jīng)過多次改進(jìn),并開始流行。C+是在C語言的基礎(chǔ)上發(fā)展和完善的,而C是吸收了其它語言的優(yōu)點逐步成為實用性很強的語言,4,C語言的主要特點是: 1、C語言是一種結(jié)構(gòu)化的程序設(shè)計語言,語言本身簡潔、使用靈活方便。既適用于設(shè)計和編寫大的系統(tǒng)程序,又適用于編寫小的控制程序,也適用科學(xué)計算,2、它既有高級語言的特點,

3、又具有匯編語言的特點。運算符豐富,除了提供對數(shù)據(jù)的算術(shù)邏輯運算外,還提供了二進(jìn)制的位運算。并且也提供了靈活的數(shù)據(jù)結(jié)構(gòu)。用C語言編寫的程序表述靈活方便,功能強大。用C語言開發(fā)的程序,其結(jié)構(gòu)性好,目標(biāo)程序質(zhì)量高,程序執(zhí)行效率高,5,3、程序的可移植性好。用C語言在某一種型號的計算機上開發(fā)的程序,基本上可以不作修改,而直接移植到其它型號和不同檔次的計算機上運行,4、程序的語法結(jié)構(gòu)不夠嚴(yán)密,程序設(shè)計的自由度大。這對于比較精通C語言的程序設(shè)計者來說,可以設(shè)計出高質(zhì)量的非常通用的程序。但對于初學(xué)者來說,要能比較熟練運用C語言來編寫程序,并不是一件容易的事情。與其它高級語言相比而言,調(diào)試程序比較困難。往往是

4、編好程序輸入計算機后,編譯時容易通過,而在執(zhí)行時還會出錯。但只要對C語言的語法規(guī)則真正領(lǐng)會,編寫程序及調(diào)試程序還是比較容易掌握的,6,隨著C語言應(yīng)用的推廣,C語言存在的一些缺陷或不足也開始流露出來,并受到大家的關(guān)注。如:C語言對數(shù)據(jù)類型檢查的機制比較弱;缺少支持代碼重用的結(jié)構(gòu);隨著軟件工程規(guī)模的擴大,難以適應(yīng)開發(fā)特大型的程度等等,7,為了克服C語言本身存在的缺點,并保持C語言簡潔、高效,與匯編語言接近的特點,1980年,貝爾實驗室的Bjarne Stroustrup博士及其同事對C語言進(jìn)行了改進(jìn)和擴充,并把Simula 67中類的概念引入到C中。并在1983年由Rick Maseitti提議正

5、式命名為C+(C Plus Plus)。后來,又把運算符的重載、引用、虛函數(shù)等功能加入到C+中,使C+的功能日趨完善。 當(dāng)前用得較為廣泛的C+有:VC+ (Visual C Plus Plus)、 BC+(Borland C Plus Plus)、AT /輸出字符串,主函數(shù),函數(shù)體開始,函數(shù)體結(jié)束,輸出流,在屏幕上打印引號內(nèi)的字符串,分號,一條完整語句的結(jié)束符,本程序編譯執(zhí)行后,在DOS屏幕上打印出 I am a student,包含文件,注釋或說明,10,編譯過程: 1)啟動Visual C+,選擇“文件”菜單中的“新建”命令,選擇“文件”標(biāo)簽中的“C+ Source File”選項。 2)

6、選擇源程序存放的目錄和輸入源程序名,單擊“確定”。 3)在編輯器中編寫源程序。 4)單擊F7或“編譯”中的“重建全部”編譯源程序,若編譯通過,單擊“執(zhí)行”,在DOS屏上看結(jié)果,任按一鍵返回編輯器,11,啟動VC+編譯系統(tǒng),12,VC+編譯系統(tǒng)界面,單擊“File”菜單中“New”命令,13,選擇“Files”選項卡,選擇C+源文件命令,輸入文件名,輸入文件存放位置,單擊選擇驅(qū)動器,選擇驅(qū)動器或目錄,14,C+源文件編輯界面,輸入C+源代碼,15,可以將此源代碼另起文件名存盤,16,選擇編譯命令,將源文件.cpp生成.obj文件,17,如果編譯出錯,會出現(xiàn)提示信息,指出錯誤的位置及種類,錯誤所在

7、行,錯誤的原因,18,雙擊錯誤所在行,光標(biāo)移到該行,19,生成可執(zhí)行文件,通過后單擊該命令運行程序,20,運行結(jié)果顯示在DOS屏上,注意:不可以在軟盤上運行程序!應(yīng)該把保存在軟盤中的源文件拷貝到硬盤的目錄中再運行,21,源程序所在目錄,未編譯前,只有一個源程序,22,編譯運行后,出現(xiàn)眾多附加文件,同時,產(chǎn)生一個子目錄Debug,23,Debug目錄中,有obj和EXE文件,24,include void main(void) cout i; /從鍵盤上輸入變量i的值 cout “i的值為:” in; / 輸出變量i的值,另一個例子,25,第二章 數(shù)據(jù)類型、運算符與表達(dá)式,26,2000H 20

8、01H 2002H 2003H 2004H,3,3+5=,5,運算器,2000H)+(2002H,用一個字節(jié)表示整數(shù),范圍為-128127;用兩個字節(jié)表示整數(shù),范圍為-32768 32767。一般用四個字節(jié)表示整數(shù)。(舉例,內(nèi)存,CPU,內(nèi)存,data,外存,Program,8,硬盤 軟盤,27,有符號數(shù),無符號數(shù),32767,32767,32766,32766,1,1,0,0,1(補碼,65535,2,65534,32767,32769,32768,32768,28,常量與變量,常量:在程序運行過程中,其值一直保持不變的量為常量。 常量也區(qū)分不同的類型:30,40 為整型,30.0,40.0

9、為實型,編輯器只是根據(jù)其表面形式來判斷其類型,變量:在程序運行過程中,其值可以改變的量為變量。 變量在程序的執(zhí)行中能夠賦值,發(fā)生變化。變量有一個名字,并在使用之前要說明其類型,一經(jīng)說明,就在內(nèi)存中占據(jù)與其類型相應(yīng)的存儲單元,29,include #define PRICE 30 /常量,在程序中保持不變 void main(void) int num, total; /定義變量,在內(nèi)存中開辟區(qū)間 num=10; /變量賦值,10為常量 total=num*PRICE; cout“total=“total; /輸出結(jié)果,其中:num=10 total=num*PRICE,是賦值號,不同于數(shù)學(xué)意義

10、上的等號,num,total,10,300,30,C+中有多種數(shù)據(jù)類型,均有常量與變量之分,各占不同的內(nèi)存空間,正確定義與使用數(shù)據(jù)是編寫程序的基本前提,31,變量名的命名方法: 變量名、數(shù)組名、函數(shù)名稱為標(biāo)識符。 標(biāo)識符只能由字母、數(shù)字、下劃線這三種字符組成,且第一個字符必須為字母或下劃線,長度不大于247個字符,大小寫不通用。(關(guān)鍵字不能作為標(biāo)識符)。 關(guān)鍵字即是VC+的語法要求中使用的字。 如 int if while 等。 正確的標(biāo)識符:INT, sum , de12, SUM等。變量必須使用前定義,以分配空間。 舉例說明,32,abc English 2xy x-y if Else b

11、(3) def Chine_bb b3y AbsFloat float,一般變量都是用匈牙利命名法命名的,int nCount; char chChoice,33,整型數(shù)據(jù),整型常量: 常量是根據(jù)其表面形式來判定,整型量即是沒有小數(shù)點的整數(shù),范圍:-231(231-1) ,有三種形式: 1)十進(jìn)制(默認(rèn)方式)43 1345 87654 2)八進(jìn)制 以0開頭 043, 056, 011 3)十六進(jìn)制 以0 x開頭 0 x12 0 xa3 0 x34 0 xdf(舉例說明,34,include void main(void) int int10,int8,int16; /定義3個整型變量 int1

12、0=10;/默認(rèn)為十進(jìn)制 int8=010;/八進(jìn)制 int16=0 x10;/十六進(jìn)制 coutint10=int10endl; coutint8=int8endl; coutint16=int16endl;,輸出 int10=10 int8=8 int16=16,35,整型變量: 分為有符號型與無符號型。 有符號型: short 在內(nèi)存中占兩個字節(jié),范圍為-215(215-1) int 在內(nèi)存中占四個字節(jié),范圍為-231(231-1) long在內(nèi)存中占四個字節(jié),范圍為-2-31231-1,無符號型:最高位不表示符號位 unsigned short 在內(nèi)存中占兩個字節(jié),范圍為0216-1

13、unsigned int 在內(nèi)存中占四個字節(jié),范圍為0232-1 unsigned long在內(nèi)存中占四個字節(jié),范圍為0232-1,36,1)整型常量亦有長短之分,常量中無unsigned型,但一個非負(fù)的整型常量可以賦給unsigned型的變量。 2)若一個常量定義為長整型數(shù),則在其后加l或L進(jìn)行區(qū)分。 如:32l 32L 564L等,內(nèi)存為其分配四個字節(jié)存儲,一個數(shù)在內(nèi)存中為,當(dāng)這個數(shù)為有符號數(shù)時,是-1;為無符號數(shù)時,是232-1 內(nèi)存中的數(shù)是以補碼的形式存放的。(舉例說明,37,include void main() unsigned short a; short int b= -1;

14、a=b; couta=aendl;,結(jié)果:65535,不同類型的整型數(shù)據(jù)間的賦值歸根到底就是一條:按存儲單元中的存儲形式直接傳送,a,b,unsigned short a,38,實型數(shù)據(jù),實型數(shù)又稱浮點數(shù),有兩種表示方式: 1)十進(jìn)制形式: 23.0 24.5 3.56789 指數(shù)形式: 23E1 145e-1 356789e1 e前有數(shù)字,后面必須是整數(shù),實型變量分單精度 float 和雙精度 double 兩種形式: float:占四個字節(jié),提供78位有效數(shù)字。 double: 占八個字節(jié),提供1516位有效數(shù)字,舉例說明,39,include void main(void) float

15、a, b; double c, d; a=0.01; b=3.45678e-2; c=3.45678e-2; d=9.7654e-5; couta=atb=bendl; coutc=ctd=dendl;,a=0.01 b=0.0345678 c=0.0345678 d=9.7654e-005 Press any key to continue,40,如果為實數(shù),則用浮點數(shù)的形式在內(nèi)存存儲,表示如下,實數(shù)是既有整數(shù)又有小數(shù)的數(shù)。 實數(shù)可以表示成:N=SRJ S 稱為尾數(shù),尾數(shù)決定有效數(shù)字,即數(shù)字的精度。 J 表示指數(shù)(階碼)。 R 是基數(shù),可取2,4,8,16等,對具體機器而言,基數(shù)取好后,就不

16、能再變了。 數(shù)有正有負(fù), 所以設(shè)置數(shù)符; 階碼亦有正負(fù), 所以設(shè)置階符,41,一般用4個字節(jié)表示一個浮點數(shù),也有用8個字節(jié)表示的,字長一定,尾數(shù)越多,精度越高;階碼越多,范圍越大。 當(dāng)計算機中出現(xiàn)小于機器所能表示的最小數(shù)時,機器只能當(dāng)零來處理,當(dāng)出現(xiàn)超過機器所能表示的最大數(shù)時,出現(xiàn)溢出現(xiàn)象,一旦出現(xiàn)溢出,就會停止運算。定點數(shù),浮點數(shù)均會出現(xiàn)溢出現(xiàn)象,42,字符型數(shù)據(jù)(char,字符型數(shù)據(jù)實際上是作為整型數(shù)據(jù)在內(nèi)存中存儲的。 計算機是以字符編碼的形式處理字符的,因此,我們在計算機內(nèi)部是以ASCII碼的形式表示所有字符的。所以7位二進(jìn)制數(shù)即可表示出一個字符,我們用一個字節(jié)的容量(8位)存儲一個字符

17、,例如:字符A的ASCII碼為0 x41或65,在內(nèi)存中表示為,在程序中表示為: char grade ;/定義一個字符型的變量空間(1個字節(jié)) grade=A; /必須用 表示,否則易與標(biāo)識符混同,內(nèi)括起來的字符表示該字符的ASCII碼,43,進(jìn)一步,由于在內(nèi)存中的形式與整型數(shù)據(jù)相同,所以,可以直接用其整型值給變量賦值,char grade; grade=65,以下的賦值形式均是等同的。 grade=A; grade=65 ; grade=0 x41; grade=0101,include void main(void) char a,b; a=A; /輸入ASCII碼 b=65; /輸入十

18、進(jìn)制數(shù) couta=aendl; coutb=bendl;,輸出: a=A b=A,即在內(nèi)存中的表示均是相同的,44,非打印字符 有些ASCII的字符代表某些操作,不能打印出來,如回車、退格等,可用兩種方式表示這些字符。 1)用ASCII碼的形式 char re=13; 2)用轉(zhuǎn)義字符 char re=n;(p15,45,46,轉(zhuǎn)義字符雖然包含2個或多個字符,但它只代表一個字符。編譯系統(tǒng)在見到字符“”時,會接著找它后面的字符,把它處理成一個字符,在內(nèi)存中只占一個字節(jié),47,典型轉(zhuǎn)義字符 : n換行 b 退格 t 下一個輸出區(qū) 若輸出中包含這些特定格式,則再加一個,輸出 c:tctc 表示為co

19、utc:tctc,可以用轉(zhuǎn)義字符表示任一一個ASCII字符 ddd (八進(jìn)制) xhh (十六進(jìn)制) 101 x41 x61 141,48,include void main(void) char c1,c2,c3,c4; char n1,n2; c1=a;/字符常量 c2=97;/十進(jìn)制 c3=x61;/轉(zhuǎn)義字符 c4=0141;/八進(jìn)制 coutc1=c1tc2=c2endl; coutc3=c3tc4=c4endl; n1=n; /轉(zhuǎn)義字符:回車 n2=t; /轉(zhuǎn)義字符:下一個輸出區(qū)(Tab) cout使用轉(zhuǎn)義字符n; coutc1=c1n2c2=c2n1; coutc3=c3n2c4=

20、c4n1;,輸出: c1=a c2=a c3=a c4=a 使用轉(zhuǎn)義字符 c1=a c2=a c3=a c4=a,49,字符串常量: 用 表示,在內(nèi)存中順序存放,以0結(jié)束。 如:CHINA,a在內(nèi)存中占一個字節(jié) a占兩個字節(jié),實際上內(nèi)存是對應(yīng)字符的ASCII碼形式,50,標(biāo)識符常量 在C+中有二種方法定義標(biāo)識符常量,一種是使用編譯預(yù)處理指令;另一種是使用C+的常量說明符const。 例如: #define PRICE 30 /在程序中凡是出現(xiàn)PRICE均用30替代 #define PI 3.1415926 #define S “China,const float pi=3.1415926; /

21、將變量pi定義為常量 (舉例說明,51,include #define PI 3.14156 #define S China void main(void) const float pi=3.14156;/變量作為常量使用 coutPI=PIendl; cout10*PI=10*PIendl; coutSendl; / PI=PI+3; / pi=pi+4; coutPI=PIendl; coutpi=piendl;,輸出: PI=3.14156 10*PI=31.4156 China PI=3.14156 pi=3.14156,52,下列常量的表示在C+中是否合法?若不合法,指出原因;若合法

22、,則指出常量的數(shù)據(jù)類型。 32767 35u 1.25e3.43L 0.0086e-32 87“Computer System” “a” a 9645 -0+0.5-.567,53,變量 1) 在程序的執(zhí)行過程中,其值可以改變的量稱為變量,2) 變量名必須用標(biāo)識符來標(biāo)識,3) 變量根據(jù)其取值的不同值域,分為不同類型的變量:整型變量、實型變量、字符型變量、構(gòu)造型變量、指針型變量等等,54,4) 對于任一變量,編譯程序要為其分配若干個字節(jié)(連續(xù)的)的內(nèi)存單元,以便保存變量的取值,5) 當(dāng)要改變一個變量的值時,就是把變量的新的取值存放到為該變量所分配的內(nèi)存單元中;用到一個變量的值時,就是從該內(nèi)存單元

23、中取出數(shù)據(jù),6) 不管什么類型的變量,通常均是變量的說明在前,使用變量在后,55,int i, j, k;/定義了三個整型變量i,j,k,float x,y,z;/定義了三個實型變量x,y,z,char c1,c2; /說明了二個字符型變量c1,c2 double dv1;/說明了一個雙精度型變量dv1,56,變量賦初值,在定義變量的同時給變量賦值,即在內(nèi)存中開辟出一個空間后馬上給此空間賦值。 但這個空間的值并不是固定不變的,在程序的運行中一樣可以改變,char a=x64, b=d; int a1=6, a2=98; a=A; b=n; a1=011; a2=121,int a=4; /定義

24、語句,在開辟空間后馬上為空間賦值 a=6; /重新為該空間賦值,4,6,57,算術(shù)運算符和算術(shù)表達(dá)式,一、算術(shù)運算符和算術(shù)表達(dá)式 + * % 用算術(shù)運算符連接起來的式子是算術(shù)表達(dá)式,兩個整數(shù)相除結(jié)果為整數(shù) 1/2=0 5/2=2,整數(shù)才可求余,余數(shù)的符號與左邊數(shù)的符號相同。 3%2=1 -3%2=-1 3%-2=1 -3%-2=-1 8%4=0,二、優(yōu)先級與結(jié)合性 () * / % +,58,三、強制轉(zhuǎn)換類型 (類型名)(表達(dá)式) (double) a (int) (x+y) (int) 6.2%4=2 在強制類型運算后原變量不變,但得到一個所需類型的中間變量,如:int x; float y

25、=5.8; x=(int)y,x=5,y=5.8,y的值沒有改變,仍是單精度浮點型,59,四、自增、自減運算符 (難點) +,6,3,7,int i, j; i=3; j = +i,i=4 j=4 +在前, 先運算,后賦值,int i, j; i=3; j = i,i=4 j=3 +在后, 先賦值,后運算,4,4,3,3,4,i=6; i+; i=i+1 i=7 +i; i=i+1 i=7,i=6; i; i=i1 i=5 i ; i=i1 i=5,6,7,60,1)自增、自減運算符只能用于變量,不可用于常量和表達(dá)式 因為表達(dá)式在內(nèi)存內(nèi)沒有具體空間,常量所占的空間不能重新賦值 3+ (x+y)

26、+ (i),若i=3, j=2 (i+) +j 等于,5,i=4, j=2,2)結(jié)合方式自右至左,優(yōu)先級最高,向右取最大 i+ (i+) i+j (i+) +j,61,賦值運算符和賦值表達(dá)式,bmw=2002,左邊必須是變量名。 若“ = ” 兩邊變量類型不同,在賦值時要進(jìn)行類型轉(zhuǎn)換。 轉(zhuǎn)換原則:根據(jù)左邊變量的類型轉(zhuǎn)換,62,少字節(jié)多字節(jié) 1)若多字節(jié)變量為unsigned ,則轉(zhuǎn)換后多余字節(jié)補零,unsigned,short int a=-1; unsigned long b; b=a,a,b,63,有符號型,符號擴展,short int a=-1; long b; b=a,2)若多字節(jié)變量

27、為有符號型,則轉(zhuǎn)換后擴展少字節(jié)的最高位,轉(zhuǎn)換后,數(shù)據(jù)的符號不變,a,b,64,多字節(jié)少字節(jié) 低位照搬,int a=-1; short int b; b=a,b=-1,int a=65535; short int b; b=a,b=-1,b,a,65,賦值表達(dá)式 a=b=5 ; b=5 a=5 =的結(jié)合性為自右至左,復(fù)合的賦值運算符 a+=3 a=a+3 x*=y+3 x=x*(y+3) x/=x-4 x=x/(x-4,x+=y x=x+y i+=j- i=i+(j,66,a=12; a+=a-=a*a,12,a=a-(a * a) =12-(12*12)=-132,a=a+(-132)=-13

28、2-132=-264,132,264,67,關(guān)系運算符和關(guān)系表達(dá)式,關(guān)系運算符(比較運算) = = = != = = 與 = a=5; 賦值運算 a= =5;判斷是否相等,= 的優(yōu)先級大于= =,3. 算術(shù)運算符的優(yōu)先級大于關(guān)系運算符的優(yōu)先級,68,關(guān)系表達(dá)式:用關(guān)系運算符將表達(dá)式連接起來稱為關(guān)系表達(dá)式。其值非真即假。在C+語言中,用非0代表真,用0表示假。關(guān)系表達(dá)式的結(jié)果只有兩個,真為1,假為0,a=2 b=3 c=4 a2 ab+c a= =2,a= =a aa b=a= =2,aA b= =a+1 c-a= =a,0,0,1,0,0,1,1,0,1,69,邏輯運算符,運算符 與 2、 i

29、nt i=0, j=1; i=3, (j+)+i ; i+=j*=3; 3、int i=1, j=0; 4、int i=1, j=1; j=i=(i=3)*2); i+=j+=2,i=3,j=1,i=3,j=3,i=6,j=6,i=4,j=3,77,各類數(shù)值型數(shù)據(jù)間的混合運算,整型、實型、字符型數(shù)據(jù)間可以混合運算,10+a+1.5-87.65*b,在進(jìn)行運算時,不同類型的數(shù)據(jù)要先轉(zhuǎn)換成同一類型的數(shù)據(jù)再進(jìn)行運算。 轉(zhuǎn)換規(guī)則如下,78,第三章 簡單的輸入輸出,79,輸入語句:cin,程序在執(zhí)行期間,接收外部信息的操作稱為程序的輸入;而把程序向外部發(fā)送信息的操作稱為程序的輸出。在C+中沒有專門的輸入

30、輸出語句,所有輸入輸出是通過輸入輸出流來實現(xiàn)的,80,要使用C+提供的輸入輸出時,必須在程序的開頭增加一行: #include 即包含輸入輸出流的頭文件“iostream.h”。有關(guān)包含文件的作用,在編譯預(yù)處理部分(第五章)作詳細(xì)介紹,81,輸入十進(jìn)制整數(shù)和實數(shù),cin . (舉例說明,int a,b; cinab;/程序運行至此停下,等待從鍵盤輸入變量值,鍵盤輸入:3 5 或:3 5 均可,輸入語句自動過濾空白字符,3,鍵盤,5,鍵盤,82,浮點型數(shù)據(jù)同整型數(shù)據(jù)一樣,float c,d; cincd,char ch1,ch2; cinch1ch2,若輸入:ab則ch1為a,ch2為b,若輸入

31、:a b則ch1為a,ch2為b,字符型變量過濾空白字符。cin格式過濾空白字符,83,float a; int i1,i2; char ch1,ch2; cini1ai2ch1ch2,輸入:34 5.678 1a b,i2:1,在缺省的情況下,cin自動跳過輸入的空格,換言之,cin不能將輸入的空格賦給字符型變量,同樣地,回車鍵也是作為輸入字符之間的分隔符,也不能將輸入的回車鍵字符賦給字符型變量,a:5.578,i1:34,ch1:a,ch2:b,84,若要把從鍵盤上輸入的每一個字符,包括空格和回車鍵都作為一個輸入字符賦給字符型變量時,必須使用函數(shù)cin.get()。其格式為: cin.ge

32、t(,cin.get()從輸入行中取出一個字符,并將它賦給字符型變量。這個語句一次只能從輸入行中提取一個字符,char c1; cin.get(c1,85,char ch1,ch2,ch3; cin.get(ch1); cin.get(ch2); cin.get(ch3,輸入:A B,則:ch1:A,并且在輸入緩沖區(qū)中保留回車鍵,ch2:空格,ch3:B,空格的ASCII碼為32,ch2,86,輸入十六進(jìn)制或八進(jìn)制數(shù)據(jù),在缺省的情況下,系統(tǒng)約定輸入的整型數(shù)是十進(jìn)制數(shù)據(jù)。當(dāng)要求按八進(jìn)制或十六進(jìn)制輸入數(shù)據(jù)時,在cin中必須指明相應(yīng)的數(shù)據(jù)類型:hex為十六進(jìn)制;oct為八進(jìn)制;dec為十進(jìn)制,87,

33、int i,j,k,l; cinhexi;/指明輸入為十六進(jìn)制數(shù) cinoctj;/指明輸入為八進(jìn)制數(shù) cink;/輸入仍為八進(jìn)制數(shù) cindecl;/指明輸入為十進(jìn)制數(shù) 當(dāng)執(zhí)行到語句cin時,若輸入的數(shù)據(jù)為: 11 11 12 12,結(jié)果:i:17,j:9,k:10,l:12,88,使用非十進(jìn)制數(shù)輸入時,要注意以下幾點: 1、八進(jìn)制或十六進(jìn)制數(shù)的輸入,只能適用于整型變量,不適用于字符型變量,實型變量,2、當(dāng)在cin中指明使用的數(shù)制輸入后,則所指明的數(shù)制一直有效,直到在接著的cin中指明輸入時所使用的另一數(shù)制為止。如上例中,輸入k的值時,仍為八進(jìn)制,89,3、輸入數(shù)據(jù)的格式、個數(shù)和類型必須與c

34、in中所列舉的變量類型一一對應(yīng)。一旦輸入出錯,不僅使當(dāng)前的輸入數(shù)據(jù)不正確,而且使得后面的提取數(shù)據(jù)也不正確,cina,b,cina b,cinab,int a, b,cinab,90,輸出數(shù)據(jù)cout 與輸入cin對應(yīng)的輸出是cout輸出流,當(dāng)要輸出一個表達(dá)式的值時,可使用cout來實現(xiàn),其一般格式為: cout .; 其中運算符“”稱為插入運算符,它將緊跟其后的表達(dá)式的值,輸出到顯示器當(dāng)前光標(biāo)的位置,91,int a=6; float f1=12.4; char s1 =“abcd”; coutatf1ts1endl,t為轉(zhuǎn)義字符Tab endl為回車或n,顯示器,顯示器,顯示器,6,12.4

35、,abcd,92,cout將雙引號中的字符串常量按其原樣輸出,char ch1=a,ch2=b; cout“c1=“ch1t“c2=“ch2endl,c1=ac2=b,int i1=4,i2=5; float a=3.5; cout“a*i1=“a*i1endl“a*i2=“a*i2endl,a*i1=14 a*i2=17.5,93,指定輸出項占用的寬度: 在輸出的數(shù)據(jù)項之間進(jìn)行隔開的另一種辦法是指定輸出項的寬度。如上面的兩個輸出語句可改寫為: cout setw(6) isetw(10)jendl,_ _ _ _ _ 4_ _ _ _ _ _ _ _ _12,cout setw(5)mset

36、w(10)j*kendl,_ _ _ _ 7_ _ _ _ _ _ _ _ 24,其中setw(6)指明其后的輸出項占用的字符寬度為6,即括號中的值指出緊跟其后的輸出項占用的字符位置個數(shù),并向右對齊。setw是“set width”的縮寫,94,使用setw()應(yīng)注意以下三點: 1、在程序的開始位置必須包含頭文件iomanip.h,即在程序的開頭增加: #include,2、括號中必須給出一個表達(dá)式(值為正整數(shù)),它指明緊跟其后輸出項的寬度,3、該設(shè)置僅對其后的一個輸出項有效。一旦按指定的寬度輸出其后的輸出項后,又回到原來的缺省輸出方式,95,輸出八、十六進(jìn)制數(shù)和科學(xué)表示法的實數(shù),對于整型數(shù)據(jù)

37、可指定以十六進(jìn)制或八進(jìn)制輸出,而對于實型數(shù)據(jù)可指定以科學(xué)表示法形式輸出。例如,設(shè)有如下一個程序: #include void main(void) float x=3.14,y=100; cout.setf(ios:scientific,ios:floatfield); /表明浮點數(shù)用科學(xué)表示法輸出 cout xt; cout yendl;,執(zhí)行該程序后的輸出為: 3.140000e+000 1.000000e+002,96,與cin中類同,當(dāng)在cout中指明以一種進(jìn)制輸出整數(shù)時,對其后的輸出均有效,直到指明又以另一種進(jìn)制輸出整型數(shù)據(jù)為止。對實數(shù)的輸出,也是這樣,一旦指明按科學(xué)表示法輸出實數(shù),

38、則接著的輸出均按科學(xué)表示法輸出,直到指明以定點數(shù)輸出為止。明確指定按定點數(shù)格式輸出(缺省的輸出方式)的語句為: cout.setf(ios:fixed,ios:floatfield,97,第四章 C+的流程控制語句,98,程序的三種基本結(jié)構(gòu),1、順序,99,3、循環(huán),100,101,if語句,判斷選擇語句,有三種形式: if(表達(dá)式) 語句,2) if(表達(dá)式) 語句1 else 語句2,if (ab) couta,if (ab) couta; else coutb,102,if(表達(dá)式1) 語句1 else if (表達(dá)式2) 語句2 . else if (表達(dá)式n) 語句n else 語句

39、n+1,103,語句1,真,真,語句2,真,語句3,真,語句4,假,假,假,假,語句5,104,注意:1) if 后可跟復(fù)合語句。 2) 注意 ;的位置。 3) 注意多重 if else 的搭配,if (ab) a=1; b=0; else a=0; b=1;,105,if (i j) i+; if (ij); i,if 總是與它上面最近的 else 配對,如要改變,用復(fù)合語句 。 注意書寫格式,相互配對的語句要對齊,106,例:輸入兩個實數(shù),按代數(shù)值由小到大次序輸出這兩個數(shù)。 void main( void ) float a,b,t; /定義變量 coutab; /給變量賦值 a:7, b

40、:3 if(ab) t=a; a=b; b=t; /交換數(shù)據(jù),用中間變量 coutatbendl;/輸出變量,7,3,7,7,3,輸出結(jié)果: 3 7,107,嵌套的條件語句(舉例說明,x=100; a=10; b=20; ok1=5; ok2=0; if(ab) if(b!=15) if(!ok1) x=1; else if (ok2) x=10; x=-1,x=-1,108,條件運算符 是C中的唯一的三目運算符。 表達(dá)式1?表達(dá)式2 :表達(dá)式3,max=ab?a:b ; / 求a, b中的大者 當(dāng) a=2 b=1 ab為真,表達(dá)式的值等于a, max值為2 當(dāng) a=1 b=2 ab為假,表達(dá)

41、式的值等于b, max值為2,注意: 條件運算符的優(yōu)先級比賦值運算符高 x=(x=3) ? x+2 : x-3 2. 結(jié)合方向自左至右 ab?a:cd?c:d 3. 三個表達(dá)式的類型可不同 z=ab?A:a+b,x=5,109,x=9, y=6, z=5; x=(x+y)%z=x%z+y%z)?1:0; coutx= xendl,x=1; y=2; z=3; x+=y+=z; couty?x+:y+)endl,y=y+z=5 x=x+5=6,9,x=0,110,void main(void ) int x=1,y=2,z=3; x+=y+=z; couty?x+:y+=y,xyz 輸出,653

42、,6536,6635,6636,6,6799,6797,9,344,3440,3441,111,執(zhí)行以下程序段后,變量a,b,c的值分別是: int x=10, y=9; int a,b,c; a=(-x= =y+)?-x:+y; b=x+; c=y,x=8 y=10 a=8,b=8 x=9,c=10,112,void main(void ) int a=5,b=1,c=0; if(a=b+c) cout“* * *n”; else cout“$ $ $n”;,*,113,switch語句,多分支選擇語句。if語句只有兩個分支,而實際問題中常常需要用到多分支的選擇。如,成績分為A(10085)

43、、B(8470)、C(6960)、D(60以下)等,114,cin.get(grade); if(grade= =A) cout“10085n”; else if (grade= =B) cout“8470n”; else if (grade= =C) cout“6960n”; else if (grade= =D) cout“no passn”; else cout“errorn,115,switch(表達(dá)式) case 常量表達(dá)式1:語句1 case 常量表達(dá)式2:語句2 case 常量表達(dá)式n:語句n default:語句n+1,switch(grade) case A:cout“100

44、85n”; case B:cout“8470n”; case C:cout“6960n”; case D:cout“no passn”; default:cout“errorn”;,如果grade為 A,則結(jié)果為,10085 8470 6960 no pass error,116,其流程為:先計算表達(dá)式的值,然后順序地與case子句中所列出的各個常量進(jìn)行比較,若表達(dá)式的值與常量中的值相等,就開始進(jìn)入相應(yīng)的case語句執(zhí)行程序,遇到case和default也不再進(jìn)行判斷,直至switch語句結(jié)束。如果要使其在執(zhí)行完相應(yīng)的語句后中止執(zhí)行下一語句,可以在語句后加break,117,switch(gr

45、ade) case A:cout“10085n”; break; case B:cout“8470n”; break; case C:cout“6960n”; break; case D:cout“no passn”; break; default:cout“errorn”;,118,注意: 1、switch與if不同,它僅能判斷一種邏輯關(guān)系,即表達(dá)式是否等于指定的常量,而 if 可以計算并判斷各種表達(dá)式,2、case子句后必須為常量,常常是整型和字符型,3、default可以省略,這時,不滿足條件什么也不執(zhí)行,119,4、case和default只起標(biāo)號的作用,順序可以顛倒,顛倒時注意后面的

46、break語句,5、多個case語句可以共用一組程序。 case A: case B: case C: cout“pass!n,120,void main(void ) int i=10; switch(i) case 9: i+; case 10: i+; case 11: i+; default: i+; cout“i=”iendl;,i=11,i=12,i=13,i=13,121,int x=1, y=0, a=0, b=0; switch( x ) case 1: switch( y ) case 0: a+; break; case 1: b+; break; case 2: a+;

47、 b+; break; case 3: a+; b+; cout“a=“at“b=”bendl,a=1,a=2 b=1,a=2b=1,122,有3個整數(shù)a,b,c,由鍵盤輸入,輸出其中最大的數(shù),123,while語句,while ( 表達(dá)式) 語句組1 語句組2,a=3; while(a100) a=a+5; cout“a=“a,當(dāng)循環(huán)語句超過一條時,要用 將語句組組合在一起,124,求 1+2+3+100,void main(void) int i=1,sum=0; /定義變量,初始化 while(i=100) /構(gòu)造循環(huán) sum=sum+i; / 循環(huán)體,多次執(zhí)行 i=i+1; cout“

48、sum=”sumendl; /輸出結(jié)果,0,1,1,2,真,3,3,真,6,4,真,10,5,真,真,100,真,101,真,5050,假,sum5050,1,2,3,3,6,4,100,5050,101,循環(huán)結(jié)束,實際上是將i不停地累加到一起,125,注意: 1、循環(huán)體如果為一個以上的語句,用 括起。 2、循環(huán)體內(nèi)或表達(dá)式中必須有使循環(huán)結(jié)束的條件,即一定有一個循環(huán)變量。 3、while表達(dá)式可以成為語句,要特別小心,126,k=2; while(k!=0) coutk, k-; coutendl,輸出:21,2,真,2,1,真,1,0,假,回車,127,void main(void) int

49、 num=0; while(num=2) num+; coutnumendl;,1 2 3,0,真,1,1,真,2,2,真,3,3,假,無,128,void main(void) int y=10; while (y-); cout“y=”yendl;,輸出:y=-1,輸出是什么? 循環(huán)幾次,10,真,無,9,真,無,真,無,1,真,無,0,假,1,循環(huán):10次,129,k=10; while( k=0 ) k=k-1; cout k,輸出:0,130,x=10; while (x!=0) x-; x=10; while (x) x-; x=10; while(x-); x=10; while

50、(-x,以下語句,循環(huán)退出時x為多少,x=0,x=0,x=-1,x=0,131,include void main() char ch; while(cin.get(ch),從鍵盤輸入2473,則程序的輸出結(jié)果是,輸出,6,6,8,9,7,7,132,dowhile語句,do 語句組1 while(表達(dá)式); 語句組2,133,求 1+2+3+100,void main(void) int i=1,sum=0; /定義變量,初始化 do /構(gòu)造循環(huán) sum=sum+i; / 循環(huán)體,多次執(zhí)行 i=i+1; while (i=100); cout“sum=”sumendl; /輸出結(jié)果,134,

51、注意: dowhile首先執(zhí)行循環(huán)體,然后再判斷表達(dá)式,至少執(zhí)行一次循環(huán)體。當(dāng)?shù)谝淮窝h(huán)表達(dá)式的值為真時,while與dowhile的結(jié)果完全一樣,否則結(jié)果不相同,135,x=0,y=0; do y+; x*=x; while (x0,輸出:y=1,x=0,1,0,假,若為while循環(huán),則一次也不執(zhí)行循環(huán)體,輸出為: y=0, x=0,136,s=7; do s-=2; while(s= =0); cout“s=”sendl,輸出:s=5,137,for語句,for(表達(dá)式1;表達(dá)式2;表達(dá)式3) 語句組1(循環(huán)體) 語句組2,for(循環(huán)變量賦初值;循環(huán)結(jié)束條件;循環(huán)變量增值,138,求

52、1+2+3+100,void main(void) int i, sum; for (i=1, sum=0; i=100; i+) sum=sum+i; cout“sum=”sumendl;,void main(void) int i, sum; i=1; sum=0; while(i=100) sum=sum+i; i=i+1; cout“sum=”sumendl;,139,注意: 1、當(dāng)型循環(huán),條件測試是在循環(huán)開始時進(jìn)行,有可能一次也進(jìn)入不了循環(huán)體,2、for語句中的三個表達(dá)式可以部分省略或全部省略, 但;不能省略,若省略表達(dá)式2,則表示循環(huán)條件為真,3、for語句中三個表達(dá)式可以是任何有

53、效的C語言表達(dá)式,140,void main(void) char i, j ; for (i=a,j=z ; ij ; i+, j-) coutij; coutendl;,輸出:azbycx.lomn,a,z,真,az,b,y,真,by,c,x,真,cx,真,真,m,n,mn,n,m,假,CR,141,以下循環(huán)結(jié)果如何? for ( i=0, k= -1; k=1; i+, k+) cout“*n,以下循環(huán)最多執(zhí)行_次,最少執(zhí)行_次 for (i=0, x=0; ix,10,1,142,循環(huán)的嵌套,一個循環(huán)體內(nèi)又包含另一個完整的循環(huán)體,稱為循環(huán)的嵌套,注意: 1、循環(huán)體內(nèi)有多個語句要用括起來

54、。 2、書寫格式要清晰,for ( ; ; ) . for ( ; ; ) .,143,void main(void) int i, j, k=0, m=0; for ( i=0; i2; i+) for ( j=0; j3; j+) k+; k- =j; m=i+j; cout“k=“k“, m=“ mendl;,輸出: k=0, m=5,0,真,0,真,1,1,真,2,2,真,3,3,假,0,1,真,0,真,1,1,真,2,2,真,3,3,假,0,144,幾種循環(huán)的比較,while ( 表達(dá)式) 語句組1 語句組2,do 語句組1 while(表達(dá)式); 語句組2,145,for(表達(dá)式1

55、;表達(dá)式2;表達(dá)式3) 語句組1 語句組2,146,最大公約數(shù)與最小公倍數(shù) 求兩自然數(shù)m , n的最大公約數(shù) 歐幾里德算法(mn) 1、m被n除得到余數(shù)r(0r n) r=m%n,m=6 n=4 r=m%n=6%4=2,while ( r=m%n ) m=n; n=r ;,最小公倍數(shù)為兩數(shù)之積除以最大公約數(shù)。4*6/2=12,2、若r=0,則算法結(jié)束,n為最大公約數(shù),否則做3,3、mn , nr , 回到1,m=4 n=2 r=m%n=4%2=0 所以,公約數(shù)=2,147,最大公約數(shù):能同時被m和n整除的最大數(shù),r=mn?n:m for(i=1; ir; i+) if(m%i=0,148,將

56、12345 的每位分別打印出來,12345105 12345/101234,1234104 1234/10123,123103 123/1012,12102 12/101,1%101 1/100,while(n) coutn%10t; n=n/10;,149,求級數(shù)公式,首先寫出通項,然后再用當(dāng)前項(第n項)除前一項,得出后一項比前一項大多少倍,通項,t=x*x/(2*n)*(2*n-1,第n項/第n-1項,表明前一項比后一項大t倍,即后一項乘t等于前一項,后一項(-1)前一項t,150,S=0;term=1;n=1;/一定要賦初值 while(fabs(term)=1e-5) S=S+ter

57、m; term=(-1)*term*x*x/(2*n)*(2*n-1); n+;,term=(-1)*term*t,前一項,當(dāng)前項,舊的,新的,后一項(-1)前一項t,設(shè)通項為term,則可以寫出迭代公式,t=x*x/(2*n)*(2*n-1,151,t=x*x/(2*n)*(2*n-1,第n項/第n-1項,第一項:term=1,第一次循環(huán):S=S+term; term=(-1)*term*t,第二次循環(huán):S=S+term; term=(-1)*term*t,這時左邊的term代表第二項,而右邊的term為第一項,這時左邊的term代表第三項,而右邊的term為第二項,term=(-1)*te

58、rm*t,前一項,當(dāng)前項,同樣是term,在循環(huán)中不斷用舊的數(shù)值去推導(dǎo)賦值出新的數(shù)值,152,S=0;term=1;n=1;/一定要賦初值 while(fabs(term)=1e-5) S=S+term; term=(-1)*term*x*x/(2*n)*(2*n-1); n+;,舊的,新的,153,break語句和continue語句,break在switch語句中,可以使流程跳過判斷體,執(zhí)行下面的程序。在循環(huán)體中,也可以從循環(huán)體內(nèi)跳出循環(huán)體,提前結(jié)束循環(huán),for ( ; ; ) cinx; if (x= =123) break;,當(dāng)輸入123時,結(jié)束循環(huán),break 只能退出一層循環(huán)或switch語句,154,a=10 ; y=0; do a+=2; y+=a; cout50) break; while (a=14,第一次:a=12 y=12,輸出:a=12 , y=12,第二次:a=16 y=28,輸出:a=16 , y=28,第三次:a=16 y=44,輸出:a=16 , y=44,第四次:a=16 y=60,輸出:a=16 , y=60,155,continue

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論