該算法的結(jié)果將單鏈表head置為空表,只需要將頭節(jié)點的指針置為null即可。
目前創(chuàng)新互聯(lián)公司已為成百上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站運營、企業(yè)網(wǎng)站設(shè)計、安仁網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
head = alloc_single_chain(10);//初始化起始結(jié)點 head-next = alloc_single_chain(11);//同理。
} void main(){ x=1; y=2;fun(x, y);...//此時仍然x=1; y=2;} 但是,函數(shù)寫成如下形式 void InitList(LinkList *head);可以實現(xiàn)引用傳遞參數(shù)的功能。
1、在初始化函數(shù)中,首先參數(shù)sqlist *L,應(yīng)該改成Sqlist *L 然后你給L-Elem_array進(jìn)行賦值操作是不對的,因為Elem_array是數(shù)組首地址,是個常量,不能進(jìn)行賦值操作。
2、C數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)是指針。好好花上幾天時間把指針搞懂再來學(xué)數(shù)據(jù)結(jié)構(gòu)會事半功倍。
3、這里提供兩種創(chuàng)建順序表的代碼,一種是由系統(tǒng)分配list占用的內(nèi)存,一種是自己動態(tài)分配的內(nèi)存,需要在程序運行之前手動釋放占用的內(nèi)存空間。
4、P是個指針變量,實際的意思是指向一個內(nèi)存地址,當(dāng)p=(char *)malloc(2) 后,p即指向了malloc函數(shù)所分配的內(nèi)存區(qū)的首地址了,并且告訴你從首地址開始后面兩個字節(jié)可用,即P[0],p[1]是可用的。
5、加*表示是指針,即函數(shù)用的是傳地址,這樣參數(shù)在函數(shù)里面被修改后是可以保存的。
6、就編一個順序表?那直接定義個數(shù)組也算是順序表了。
void InitList(LinkList *head);可以實現(xiàn)引用傳遞參數(shù)的功能。在需要函數(shù)內(nèi)部修改鏈表頭指針時,用該形式可以解決該問題。而void InitList(LinkList head) 不可以在函數(shù)內(nèi)部修改鏈表頭指針。
你分配的空間也是給臨時的變量L分配,而不是main里面的L。 引用的話,則只有一個L,所以可以。一個很經(jīng)典的小例子,void swap(int &a,int &b)。就是交換a.b的值的函數(shù)。如果,沒用&的話,你看看是行不通的。
這一句是動態(tài)分配一個LNode型結(jié)點,并返回LNode*型空間,即給頭結(jié)點分配一個空間。你前面確實聲明了一個頭指針,但關(guān)鍵是頭指針并沒有指向頭結(jié)點。
C語言(數(shù)據(jù)結(jié)構(gòu))順序表的初始化需要申請結(jié)點空間。
在內(nèi)存在不僅僅是一個地址,還分配了空間,就像你定義了一個數(shù)組一樣,已經(jīng)在內(nèi)存存在空間了,不需要再分配了??傮w來說就是你定義的是指針的話就要分配空間。