C程序設(shè)計(jì)實(shí)踐_第1頁(yè)
C程序設(shè)計(jì)實(shí)踐_第2頁(yè)
C程序設(shè)計(jì)實(shí)踐_第3頁(yè)
C程序設(shè)計(jì)實(shí)踐_第4頁(yè)
C程序設(shè)計(jì)實(shí)踐_第5頁(yè)
已閱讀5頁(yè),還剩43頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

提綱目的與意義編程能力的重要性C語(yǔ)言的重要性C程序設(shè)計(jì)實(shí)踐的目的幾點(diǎn)希望主要知識(shí)點(diǎn)回顧用指針處理鏈表文件操作目的與意義編程能力的重要性工科專業(yè)離不開編程電子信息類專業(yè)更離不開編程除管理、銷售類職位外,所有電子信息類職位都需要具備一定的編程能力所有研究生都需要編程幾乎所有大公司的筆試題中,編程都占有一定比重目的與意義C語(yǔ)言的重要性編程語(yǔ)言的典型代表所有流行的編程語(yǔ)言中都有C語(yǔ)言的影子C++、C#、Java、ASP……Verilog、SystemC…電子信息類專業(yè)通用編程語(yǔ)言DSP開發(fā)算法仿真目的與意義C程序設(shè)計(jì)實(shí)踐的目的鞏固所學(xué)知識(shí)深入理解結(jié)構(gòu)體、指針、鏈表、動(dòng)態(tài)分配內(nèi)存和文件操作等C程序設(shè)計(jì)中的中高級(jí)技術(shù)熟練掌握C語(yǔ)言的調(diào)試方法初步培養(yǎng)良好的編程習(xí)慣和編程風(fēng)格初步學(xué)習(xí)程序文檔的撰寫方法目的與意義幾點(diǎn)希望團(tuán)隊(duì)協(xié)作;所有同學(xué)要付出勞動(dòng);互幫互學(xué);杜絕抄襲;盡可能提高代碼可讀性;規(guī)范化的文檔;題目實(shí)驗(yàn)室物料管理系統(tǒng)航班信息管理系統(tǒng)個(gè)人記賬系統(tǒng)運(yùn)動(dòng)會(huì)管理系統(tǒng)完成方式以分組形式完成,每組3人,每組推選組長(zhǎng)一名(最好在小班范圍內(nèi)組合)。分組名單請(qǐng)各小班學(xué)委在第一周周三前上報(bào),指導(dǎo)老師確認(rèn)后給各組分配組號(hào)??己朔绞娇傇u(píng)分分為兩部分分組答辯:占60%程序檢查以各組依次答辯的方式進(jìn)行,根據(jù)每組的整體成績(jī)及每個(gè)組員的個(gè)人分工與貢獻(xiàn),分別給定每個(gè)同學(xué)的成績(jī)實(shí)驗(yàn)報(bào)告:占40%。時(shí)間安排第一周的第一天:上課,說明課程設(shè)計(jì)要求,講解題目第一周的其余時(shí)間:學(xué)生調(diào)研、進(jìn)行可行性研究、確定程序的系統(tǒng)框架。第二周:學(xué)生根據(jù)所選題目開發(fā)出一個(gè)基本系統(tǒng),進(jìn)行調(diào)試和測(cè)試,并加以完善。其他說明實(shí)驗(yàn)場(chǎng)地主樓1121機(jī)房,憑學(xué)生證免費(fèi)上機(jī)。機(jī)房開放時(shí)間:課程設(shè)計(jì)兩周中,上午8:30~11:30,下午1:30~4:30。調(diào)試環(huán)境:VC++2008QQ群:115144918FTP:地址9

端口:21user:cprogram111pswd:bupt111文件夾:cprogram111用指針處理鏈表

鏈表是一種常見的重要的數(shù)據(jù)結(jié)構(gòu),是動(dòng)態(tài)地進(jìn)行存儲(chǔ)分配的一種結(jié)構(gòu)。鏈表的組成:頭指針:存放一個(gè)地址,該地址指向一個(gè)元素

結(jié)點(diǎn):用戶需要的實(shí)際數(shù)據(jù)和鏈接節(jié)點(diǎn)的指針用指針處理鏈表

用結(jié)構(gòu)體建立鏈表:

struct

student{int

num;

float

score;

struct

student*next;};

其中成員num和score用來(lái)存放結(jié)點(diǎn)中的有用數(shù)據(jù)(用戶需要用到的數(shù)據(jù)),next是指針類型的成員,它指向structstudent類型數(shù)據(jù)(這就是next所在的結(jié)構(gòu)體類型)用指針處理鏈表

簡(jiǎn)單鏈表舉例

#include<stdio.h>

#defineNULL0

structstudent

{longnum;floatscore;structstudent*next;};

main()

{structstudenta,b,c,*head,*p;

a.num=99101;a.score=89.5;

b.num=99103;b.score=90;

c.num=99107;c.score=85;

head=&a;a.next=&b;b.next=&c;

c.next=NULL;p=head;

do{printf("%ld%5.1f\n",p->num,p->score);

p=p->next;}while(p!=NULL);}用指針處理鏈表程序分析:開始時(shí)使head指向a結(jié)點(diǎn),a.next指向b結(jié)點(diǎn),b.next指向c結(jié)點(diǎn),這就構(gòu)成鏈表關(guān)系?!癱.next=NULL”的作用是使c.next不指向任何有用的存儲(chǔ)單元。在輸出鏈表時(shí)要借助p,先使p指向a結(jié)點(diǎn),然后輸出a結(jié)點(diǎn)中的數(shù)據(jù),“p=p->next”是為輸出下一個(gè)結(jié)點(diǎn)作準(zhǔn)備。p->next的值是b結(jié)點(diǎn)的地址,因此執(zhí)行“p=p->next”后p就指向b結(jié)點(diǎn),所以在下一次循環(huán)時(shí)輸出的是b結(jié)點(diǎn)中的數(shù)據(jù)。用指針處理鏈表

處理動(dòng)態(tài)鏈表所需的函數(shù)庫(kù)函數(shù)提供動(dòng)態(tài)地開辟和釋放存儲(chǔ)單元的有關(guān)函數(shù):malloc函數(shù)其函數(shù)原型為void*malloc(unsignedintsize);其作用是在內(nèi)存的動(dòng)態(tài)存儲(chǔ)區(qū)中分配一個(gè)長(zhǎng)度為size的連續(xù)空間。此函數(shù)的值(即“返回值”)是一個(gè)指向分配域起始地址的指針(類型為void)。如果此函數(shù)未能成功地執(zhí)行(例如內(nèi)存空間不足),則返回空指針(NULL)。需強(qiáng)制類型轉(zhuǎn)換

用指針處理鏈表

(2)calloc函數(shù)其函數(shù)原型為void*calloc(unsignedn,unsignedsize);其作用是在內(nèi)存的動(dòng)態(tài)存儲(chǔ)區(qū)中分配n個(gè)長(zhǎng)度為size的連續(xù)空間。函數(shù)返回一個(gè)指向分配域起始地址的指針;如果分配不成功,返回NULL。用calloc函數(shù)可以為一維數(shù)組開辟動(dòng)態(tài)存儲(chǔ)空間,n為數(shù)組元素個(gè)數(shù),每個(gè)元素長(zhǎng)度為size用指針處理鏈表

(3)free函數(shù)其函數(shù)原型為voidfree(void*p);其作用是釋放由p指向的內(nèi)存區(qū),使這部分內(nèi)存區(qū)能被其他變量使用。p是最近一次調(diào)用malloc或caloc函數(shù)時(shí)返回的值free函數(shù)無(wú)返回值.

用指針處理鏈表

建立動(dòng)態(tài)鏈表所謂建立動(dòng)態(tài)鏈表是指在程序執(zhí)行過程中從無(wú)到有地建立起一個(gè)鏈表,即一個(gè)一個(gè)地開辟結(jié)點(diǎn)和輸入各結(jié)點(diǎn)數(shù)據(jù),并建立起前后相連的關(guān)系寫一函數(shù)建立一個(gè)有3名學(xué)生數(shù)據(jù)的單向動(dòng)態(tài)鏈表.算法如圖圖11-12用指針處理鏈表

算法的實(shí)現(xiàn):我們約定學(xué)號(hào)不會(huì)為零,如果輸入的學(xué)號(hào)為0,則表示建立鏈表的過程完成,該結(jié)點(diǎn)不應(yīng)連接到鏈表中。如果輸入的p1->num不等于0,則輸入的是第一個(gè)結(jié)點(diǎn)數(shù)據(jù)(n=1),令head=p1,即把p1的值賦給head,也就是使head也指向新開辟的結(jié)點(diǎn)p1所指向的新開辟的結(jié)點(diǎn)就成為鏈表中第一個(gè)結(jié)點(diǎn)用指針處理鏈表

算法的實(shí)現(xiàn):

再開辟另一個(gè)結(jié)點(diǎn)并使p1指向它,接著輸入該結(jié)點(diǎn)的數(shù)據(jù).如果輸入的p1->num≠0,則應(yīng)鏈入第2個(gè)結(jié)點(diǎn)(n=2),將新結(jié)點(diǎn)地址賦給第一個(gè)結(jié)點(diǎn)的next成員.接著使p2=p1,也就是使p2指向剛才建立的結(jié)點(diǎn)用指針處理鏈表

算法的實(shí)現(xiàn):再開辟一個(gè)結(jié)點(diǎn)并使p1指向它,并輸入該結(jié)點(diǎn)的數(shù)據(jù).在第三次循環(huán)中,由于n=3(n≠1),又將p1的值賦給p2->next,也就是將第3個(gè)結(jié)點(diǎn)連接到第2個(gè)結(jié)點(diǎn)之后,并使p2=p1,使p2指向最后一個(gè)結(jié)點(diǎn).圖11-15用指針處理鏈表

算法的實(shí)現(xiàn):再開辟一個(gè)新結(jié)點(diǎn),并使p1指向它,輸入該結(jié)點(diǎn)的數(shù)據(jù)。由于p1->num的值為0,不再執(zhí)行循環(huán),此新結(jié)點(diǎn)不應(yīng)被連接到鏈表中.將NULL賦給p2->next.建立鏈表過程至此結(jié)束,p1最后所指的結(jié)點(diǎn)未鏈入鏈表中,第三個(gè)結(jié)點(diǎn)的next成員的值為NULL,它不指向任何結(jié)點(diǎn)。用指針處理鏈表

建立鏈表的函數(shù)如下:

#include<stdio.h>#include<malloc.h>#defineNULL0//令NULL代表0,用它表示空地址#defineLENsizeof(structstudent)//令LEN代表struct//student類型數(shù)據(jù)的長(zhǎng)度

structstudent{longnum;floatscore;structstudent*next;};intn;//n為全局變量,本文件模塊中各函數(shù)均可使用它用指針處理鏈表

structstudent*creat(){structstudent*head;structstudent*p1,*p2;n=0;

p1=p2=(structstudent*)malloc(LEN);scanf("%ld,%f",&p1->num,&p1->score);head=NULL;while(p1->num!=0){

n=n+1; if(n==1)head=p1; elsep2->next=p1;

p2=p1; p1=(structstudent*)malloc(LEN); scanf("%ld,%f",&p1->num,&p1->score); }p2->next=NULL;return(head);}用指針處理鏈表

輸出鏈表首先要知道鏈表第一個(gè)結(jié)點(diǎn)的地址,也就是要知道head的值。然后設(shè)一個(gè)指針變量p,先指向第一個(gè)結(jié)點(diǎn),輸出p所指的結(jié)點(diǎn),然后使p后移一個(gè)結(jié)點(diǎn),再輸出,直到鏈表的尾結(jié)點(diǎn)。用指針處理鏈表

對(duì)鏈表的刪除操作從一個(gè)動(dòng)態(tài)鏈表中刪去一個(gè)結(jié)點(diǎn),并不是真正從內(nèi)存中把它抹掉,而是把它從鏈表中分離開來(lái),只要撤銷原來(lái)的鏈接關(guān)系即可。用指針處理鏈表

對(duì)鏈表的插入操作

對(duì)鏈表的插入是指將一個(gè)結(jié)點(diǎn)插入到一個(gè)已有的鏈表中。為了能做到正確插入,必須解決兩個(gè)問題:①怎樣找到插入的位置;②怎樣實(shí)現(xiàn)插入。用指針處理鏈表

先用指針變量p0指向待插入的結(jié)點(diǎn),p1指向第一個(gè)結(jié)點(diǎn)將p0->num與p1->num相比較,如果p0->num>p1->num,則待插入的結(jié)點(diǎn)不應(yīng)插在p1所指的結(jié)點(diǎn)之前。此時(shí)將p1后移,并使p2指向剛才p1所指的結(jié)點(diǎn).用指針處理鏈表

再將p1->num與p0->num比,如果仍然是p0->num大,則應(yīng)使p1繼續(xù)后移,直到p0->num<=p1->num為止。這時(shí)將p0所指的結(jié)點(diǎn)插到p1所指結(jié)點(diǎn)之前。但是如果p1所指的已是表尾結(jié)點(diǎn),則p1就不應(yīng)后移了。如果p0->num比所有結(jié)點(diǎn)的num都大,則應(yīng)將p0所指的結(jié)點(diǎn)插到鏈表末尾。

如果插入的位置既不在第一個(gè)結(jié)點(diǎn)之前,又不在表尾結(jié)點(diǎn)之后,則將p0的值賦給p2->next,使p2->next指向待插入的結(jié)點(diǎn),然后將p1的值賦給p0->next,使得p0->next指向p1指向的變量用指針處理鏈表

算法:C文件概述文件的定義所謂文件一般指存儲(chǔ)在外部介質(zhì)(如磁盤磁帶)上數(shù)據(jù)的集合.操作系統(tǒng)是以文件為單位對(duì)數(shù)據(jù)進(jìn)行管理的.文件程序數(shù)據(jù)區(qū)輸出文件緩沖區(qū)輸入文件緩沖區(qū)C文件概述根據(jù)數(shù)據(jù)的組織形式,文件可分為ASCII文件,即文本文件每個(gè)字節(jié)存放一個(gè)ASCII代碼,代表一個(gè)字符二進(jìn)制文件把內(nèi)存中的數(shù)據(jù)按其在內(nèi)存中的存儲(chǔ)形式原樣輸出到磁盤上存放可節(jié)省存儲(chǔ)空間,但一個(gè)字節(jié)并不對(duì)

應(yīng)一個(gè)字符文件指針在緩沖文件系統(tǒng)中,每個(gè)被使用的文件都要在內(nèi)存中開辟一個(gè)區(qū),存放文件的有關(guān)信息.這些信息保存在一個(gè)結(jié)構(gòu)體變量中,該結(jié)構(gòu)體類型由系統(tǒng)定義,取名為FILEVisualC++在stdio.h文件中有以下的文件類型聲明:#ifndef_FILE_DEFINEDstruct_iobuf{char*_ptr;int_cnt;char*_base;int_flag;int_file;int_charbuf;int_bufsiz;char*_tmpfname;};typedefstruct_iobufFILE;#define_FILE_DEFINED#endif文件類型指針文件型指針變量:FILE*fp;fp是一個(gè)指向FILE類型結(jié)構(gòu)體的指針變量??梢允筬p指向某一個(gè)文件的結(jié)構(gòu)體變量,從而通過該結(jié)構(gòu)體變量中的文件信息能夠訪問該文件。如果有n個(gè)文件,一般應(yīng)設(shè)n個(gè)指針變量,使它們分別指向n個(gè)文件,以實(shí)現(xiàn)對(duì)文件的訪問。文件的打開與關(guān)閉一.文件的打開(fopen函數(shù))函數(shù)調(diào)用:FILE*fp;fp=fopen(文件名,使用文件方式);①需要打開的文件名,也就是準(zhǔn)備訪問的文件的名字;②使用文件的方式(“讀”還是“寫”等);③讓哪一個(gè)指針變量指向被打開的文件。

文件的打開與關(guān)閉文件使用方式含義 “r”(只讀)為輸入打開一個(gè)文本文件“w”(只寫)為輸出打開一個(gè)文本文件“a”(追加)向文本文件尾增加數(shù)據(jù)“rb”(只讀)為輸入打開一個(gè)二進(jìn)制文件“wb”(只寫)為輸出打開一個(gè)二進(jìn)制文件"ab“(追加)向二進(jìn)制文件尾增加數(shù)據(jù)"r+“(讀寫)為讀/寫打開一個(gè)文本文件"w+”(讀寫)為讀/寫建立一個(gè)新的文本文件"a+”(讀寫)為讀/寫打開一個(gè)文本文件"rb+“(讀寫)為讀/寫打開一個(gè)二進(jìn)制文件“wb+“(讀寫)為讀/寫建立一個(gè)新的二進(jìn)制文件“ab+”(讀寫)為讀/寫打開一個(gè)二進(jìn)制文件文件的打開與關(guān)閉打開文件常用方法:if((fp==fopen(“file1”,”r”))==NULL){

printf(“Cannotopenthisfile\n”);exit(0);}文件的打開與關(guān)閉二.文件的關(guān)閉(fclose函數(shù))函數(shù)調(diào)用:fclose(文件指針);函數(shù)功能:

使文件指針變量不指向該文件,也就是文件指針變量與文件“脫鉤”,此后不能再通過該指針對(duì)原來(lái)與其相聯(lián)系的文件進(jìn)行讀寫操作

返回值:關(guān)閉成功返回值為0;否則返回EOF(-1)

文件的讀寫一.字符輸入輸出函數(shù)(fputs()和fgets())fputs函數(shù)函數(shù)調(diào)用:fputs(ch,fp);函數(shù)功能:

將字符(ch的值)輸出到fp所指向的文件中去。返回值:如果輸出成功,則返回值就是輸出的字符;如果輸出失敗,則返回一個(gè)EOF.文件的讀寫fgets函數(shù)函數(shù)調(diào)用:ch=fgets(fp);函數(shù)功能:

從指定的文件讀入一個(gè)字符,該文件必須是以讀或讀寫方式打開的。

返回值:讀取成功一個(gè)字符,賦給ch。如果遇到文件結(jié)束符,返回一個(gè)文件結(jié)束標(biāo)志EOF。文件的讀寫二.數(shù)據(jù)塊讀寫函數(shù)(fread()和fwrite())函數(shù)調(diào)用:fread(buffer,size,count,fp);fwrite(buffer,size,count,fp);參數(shù)說明:buffer:是一個(gè)指針。對(duì)fread來(lái)說,它是讀入數(shù)據(jù)的存放地址。對(duì)fwrite來(lái)說,是要輸出數(shù)據(jù)的地址(均指起始地址)。size:

要讀寫的字節(jié)數(shù)。count:

要進(jìn)行讀寫多少個(gè)size字節(jié)的數(shù)據(jù)項(xiàng)。fp:

文件型指針。文件的讀寫

使用舉例:若文件以二進(jìn)制形式打開:

fread(f,4,2,fp);

此函數(shù)從fp所指向的文件中讀入2個(gè)4個(gè)字節(jié)的數(shù)據(jù),存儲(chǔ)到數(shù)組f中。文件的讀寫使用舉例:若有如下結(jié)構(gòu)類型:structstudent_type{charname[10];intnum;intage;charaddr[30];}stud[40];可以用fread和fwrite來(lái)進(jìn)行數(shù)據(jù)的操作:for(i=0;i<40;i++)

fread(&stud[i],sizeof(structstudent_type),1,fp);

for(i=0;i<40,i++)fwrite(&stud[i],sizeof(structstudent_type),1,fp);

文件的讀寫使用舉例:從鍵盤輸入4個(gè)學(xué)生的有關(guān)數(shù)據(jù),然后把它們轉(zhuǎn)存到磁盤文件上去。

#include<stdio.h>#defineSIZE4structstudent_type{ charname[10];intnum;intage;charaddr[15];}stud[SIZE];/*定義結(jié)構(gòu)*/§13.4文件的讀寫(續(xù))voidsave(){FILE*fp;inti;if((fp=fopen("stu_list","wb"))==NULL){printf("cannotopenfile\n");return;}for(i=0;i<SIZE;i++)/*二進(jìn)制寫*/if(fwrite(&stud[i],sizeof(structstudent_type),1,fp)!=1)printf(“filewriteerror\n”);/*出錯(cuò)處理*/fclose(fp);}/*關(guān)閉文件*/

main(){inti;for(i=0;i<SIZE;i++)/*從鍵盤讀入學(xué)生信息*/scanf("%s%d%d%s",stud[i].name,&stud[i].num,&stud[i].age,stud[i].addr);save();}/*調(diào)用save()保存學(xué)生信息*/驗(yàn)證在磁盤文件“stu_list”中是否已存在此數(shù)據(jù),用以下程序從“stu_list”文件中讀入數(shù)據(jù),然后在屏幕上輸出。

#include<stdio.h>#defineSIZE4structstudent_type{ charname[10];intnum;intage;charaddr[15];}stud[SIZE];main(){ inti; FILE*fp; fp=fopen("stu_list","rb"); for(i=0;i<SIZE;i++)

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論