版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、C 程式設(shè)計(jì)—結(jié)構(gòu),臺(tái)大資訊工程學(xué)系資訊系統(tǒng)訓(xùn)練班,課程大綱,C語(yǔ)言簡(jiǎn)介基本資料型態(tài), 變數(shù), 基本輸入輸出控制敘述- 選擇控制與重覆控制 陣列 函式 指標(biāo) 字元與字串 結(jié)構(gòu) 檔案處理,本次課程大綱,資料型態(tài)別名 (typedef)結(jié)構(gòu)(Structure)結(jié)構(gòu)陣列結(jié)構(gòu)與函式聯(lián)合(Union)列舉資料型態(tài) (enum),typedef型態(tài)定義 (1),typedef資料型態(tài)識(shí)別字(別名);資料型
2、態(tài)是識(shí)別字所對(duì)應(yīng)的真實(shí)資料型態(tài),它可以是C語(yǔ)言的基本資料型態(tài),或其他已經(jīng)定義過(guò)的自訂資料型態(tài),或已經(jīng)使用typedef定義過(guò)的別名。識(shí)別字(別名),一旦經(jīng)由typedef定義之後,在程式中就可以使用該別名來(lái)宣告變數(shù),而實(shí)際上,該別名將會(huì)被編譯器代替為原來(lái)的資料型態(tài)。,typedef型態(tài)定義 (2),範(fàn)例:typedef int score; /* 定義資料型態(tài)的別名 */score student01,stud
3、ent02;範(fàn)例:typedef char * STRING; /* 定義資料型態(tài)的別名 */STRING str1="Book";例子,結(jié)構(gòu) (structure) (1),由於每一種資料可能擁有不同的資料型態(tài),因此,我們有的時(shí)候無(wú)法單純使用多維陣列來(lái)加以存放資料,例如:我們要記錄全班同學(xué)的成績(jī),每一位同學(xué)的資料為學(xué)號(hào)(字串資料型態(tài))、計(jì)概成績(jī)(整數(shù)資料型態(tài))、數(shù)學(xué)成績(jī)(整數(shù)資料型態(tài))、英文成
4、績(jī)(整數(shù)資料型態(tài))、平均成績(jī)(浮點(diǎn)數(shù)資料型態(tài)),如下圖。,結(jié)構(gòu) (structure) (3),結(jié)構(gòu)能夠結(jié)合數(shù)個(gè)彼此相關(guān)的變數(shù)在一個(gè)名稱(chēng)之下, 並可包含許多不同資料型態(tài)的變數(shù). 和結(jié)構(gòu)相比, 陣列也只能包含相同資料型態(tài)的元素. struct 結(jié)構(gòu)型態(tài) { 資料型態(tài) 變數(shù)1; 資料型態(tài) 變數(shù)2; ………………….. 資料型態(tài) 變數(shù)3;
5、 };,結(jié)構(gòu) (structure)定義,struct開(kāi)始定義一個(gè)結(jié)構(gòu)student稱(chēng)為該結(jié)構(gòu)的標(biāo)籤(struct tag)struct student可以用來(lái)定義此結(jié)構(gòu)型態(tài)的變數(shù), 每一個(gè)結(jié)構(gòu)定義必須以分號(hào)作為結(jié)束.struct student{char stu_id[12]; /* 學(xué)號(hào) */int ScoreComputer; /* 計(jì)概 */
6、int ScoreMath; /* 數(shù)學(xué) */int ScoreEng; /* 英文 */float ScoreAvg; /* 平均成績(jī) */};,結(jié)構(gòu)的記憶體內(nèi)容,,結(jié)構(gòu)宣告,struct結(jié)構(gòu)名稱(chēng) 變數(shù)或陣列名稱(chēng)struct student John;struct student IM[50]; s
7、truct 結(jié)構(gòu)資料型態(tài)名稱(chēng){ 結(jié)構(gòu)主體 }結(jié)構(gòu)變數(shù)名稱(chēng);,struct X{ …}Y;,存取結(jié)構(gòu) (1),結(jié)構(gòu)體變數(shù).資料項(xiàng)struct student John; /* John是一個(gè)普通結(jié)構(gòu)體變數(shù) */………………John.ScoreMath=86;John.ScoreAvg=76.67;結(jié)構(gòu)體指標(biāo)變數(shù)->資料項(xiàng) struct student John; /*
8、John一個(gè)普通結(jié)構(gòu)體變數(shù) */struct student *pJohn; /* pJohn是一個(gè)結(jié)構(gòu)體指標(biāo)變數(shù)(指向結(jié)構(gòu)體變數(shù)的指標(biāo)) */pJohn = &John; /* pJohn指標(biāo)指向John變數(shù) */………………pJohn->ScoreMath=86;pJohn->ScoreAvg=76.67;,存取結(jié)構(gòu) (2),結(jié)構(gòu)中的成員可以透過(guò)點(diǎn)運(yùn)算符號(hào) . 進(jìn)行存取
9、.例子1: 建立一個(gè)存放學(xué)生資料的結(jié)構(gòu).例子2: 一開(kāi)始就給結(jié)構(gòu)初始值.例子3: 輸入某學(xué)生的出生日期, 姓名及學(xué)號(hào).,結(jié)構(gòu)與指標(biāo) (1),struct student{ char name[20]; int num;};struct student *stud;,結(jié)構(gòu)與指標(biāo) (2),若要存取結(jié)構(gòu)指標(biāo)變數(shù)的成員, 必須使用下列的方法:student->name;或(*student)
10、.name;,輸入一個(gè)學(xué)生的資料, 並且將他輸出,結(jié)構(gòu)陣列,利用結(jié)構(gòu)可以存放個(gè)人的許多資料, 若宣告成陣列的話(huà),則可以存放一群人的資料.struct{ char name[20]; int num;} class[40];class[0].name : 第一個(gè)成員的name元素class[0].num : 第一個(gè)成員的num元素…..以此類(lèi)推,結(jié)構(gòu)陣列的記憶體內(nèi)容,,struct student Jo
11、hn;struct student IM[50];,例子,輸入三個(gè)學(xué)生的學(xué)號(hào),姓名及成績(jī)並列印出來(lái).,巢狀結(jié)構(gòu),結(jié)構(gòu)中的成員也是結(jié)構(gòu)時(shí), 可以用巢狀結(jié)構(gòu)來(lái)處理.例子,結(jié)構(gòu)與函式,當(dāng)函式的參數(shù)的型式為結(jié)構(gòu)時(shí),將結(jié)構(gòu)型態(tài)傳給函式的方式將和一般的資料型態(tài)相同.例子1: 個(gè)別傳送結(jié)構(gòu)成員例子2: 整個(gè)結(jié)構(gòu)傳送例子3: 輸入5個(gè)學(xué)生的資料,並輸出,練習(xí),建立一個(gè)員工結(jié)構(gòu), 裡面有 name, age, address, salary
12、, phone的資料結(jié)構(gòu).由使用者輸入5個(gè)員工資料.根據(jù)name對(duì)員工資料做排序.提供功能可以透過(guò)name找尋該員工資料.,聯(lián)合 (union),聯(lián)合與結(jié)構(gòu)相當(dāng)類(lèi)似,兩者之間的差異在於結(jié)構(gòu)中的資料型態(tài)必須佔(zhàn)用不同的記憶體空間,而聯(lián)合可以使不同的資料型態(tài)佔(zhàn)用相同的記憶體空間.聯(lián)合變數(shù)的長(zhǎng)度是其中的最大值.union{int one; float two;} num;,聯(lián)合 (union) 與結(jié)構(gòu),例子,利
13、用sizeof()比較結(jié)構(gòu)和聯(lián)合在記憶體中所佔(zhàn)空間的差異.輸入一個(gè)員工的加班時(shí)數(shù)及正常上班時(shí)數(shù),並計(jì)算出該員工薪資.,enum列舉集合,希望變數(shù)內(nèi)容被侷限在某些合法的範(fàn)圍內(nèi),此時(shí),我們可以將所有可能的狀況列舉出來(lái),並透過(guò)C語(yǔ)言提供的進(jìn)階資料結(jié)構(gòu)enum來(lái)加以宣告。定義語(yǔ)法enum 列舉資料型態(tài)名稱(chēng){ 此資料型態(tài)內(nèi)所有可能的成員 };enum manufacturer { IBM, MAXTOR,WD,SEAGATE };
14、enum manufacturer HardDisk;enum 列舉資料型態(tài)名稱(chēng){ 此資料型態(tài)內(nèi)所有可能的成員 }變數(shù)1,變數(shù)2,….; enum animal { dog,cat,bird } pet;,練習(xí),例子改寫(xiě)例子,今天學(xué)到了什麼,如何使用資料型態(tài)別名 (typedef)如何使用結(jié)構(gòu)(Structure)如何使用結(jié)構(gòu)陣列如何使用結(jié)構(gòu)與函式如何使用聯(lián)合(Union)如何使用列舉資料型態(tài) (enum)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- ic設(shè)計(jì)產(chǎn)業(yè) - 國(guó)立臺(tái)灣大學(xué) 資訊工程學(xué)系
- 國(guó)立中興大學(xué)法商學(xué)院經(jīng)濟(jì)學(xué)系學(xué)生事務(wù)委員會(huì)組織章程
- 國(guó)立大學(xué)生命科學(xué)通識(shí)教育之分析與改革
- powerpoint 簡(jiǎn)報(bào) - 國(guó)立臺(tái)灣大學(xué) 財(cái)務(wù)金融學(xué)系暨研 …
- 學(xué)習(xí)歷程檔案的教學(xué)表格設(shè)計(jì)
- 資訊融入教學(xué)團(tuán)隊(duì)行政規(guī)劃與運(yùn)作
- 作業(yè)流程分析 - 國(guó)立中山大學(xué)企業(yè)管理學(xué)系
- 材料科學(xué)工程學(xué)系九十三學(xué)年度入學(xué)學(xué)生必修科目名 …
- 中華大學(xué)行政管理學(xué)系
- 書(shū)名我國(guó)大學(xué)入學(xué)制度改革建議書(shū) 大學(xué)多元入學(xué)方案
- 2國(guó)立嘉義大學(xué)師範(fàn)學(xué)院教育學(xué)系導(dǎo)師制度實(shí)施要點(diǎn)%20(1)docx
- 主題探索教學(xué)設(shè)計(jì)(教案)
- 學(xué)校創(chuàng)新課程與教學(xué)發(fā)表比賽計(jì)畫(huà)
- 體育科教學(xué)活動(dòng)設(shè)計(jì)教案
- 靜宜大學(xué)oo學(xué)系系學(xué)會(huì)組織章程草案(範(fàn)例)
- 高中「健康與護(hù)理」課程ㄧ年級(jí)教學(xué)活動(dòng)設(shè)計(jì)
- 國(guó)立臺(tái)灣大學(xué)人事制度簡(jiǎn)介
- 國(guó)立屏東科技大學(xué)各學(xué)院院長(zhǎng)遴選辦法(修正草案)
- 逢甲大學(xué)土地管理學(xué)系 學(xué)生職涯路徑說(shuō)明
- 大班教學(xué)計(jì)畫(huà)
評(píng)論
0/150
提交評(píng)論