C語言 數(shù)據(jù)結(jié)構(gòu)之連續(xù)存儲(chǔ)數(shù)組的算法
數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組定義及基本操作
數(shù)據(jù)結(jié)構(gòu)中最基本的一個(gè)結(jié)構(gòu)就是線性結(jié)構(gòu),而線性結(jié)構(gòu)又分為連續(xù)存儲(chǔ)結(jié)構(gòu)和離散存儲(chǔ)結(jié)構(gòu)。所謂的連續(xù)存儲(chǔ)結(jié)構(gòu)其實(shí)就是數(shù)組。
數(shù)組本質(zhì)其實(shí)也是數(shù)據(jù)的一種存儲(chǔ)方式,既然有了數(shù)據(jù)的存儲(chǔ),就會(huì)涉及到如何對(duì)數(shù)據(jù)進(jìn)行尋址的問題。首先,先說一下在數(shù)組中數(shù)據(jù)是如何存儲(chǔ)的,在內(nèi)存中,數(shù)組中的數(shù)據(jù)是以一組連續(xù)的數(shù)據(jù)集合的形式存在于內(nèi)存中。當(dāng)我們?cè)L問存在于內(nèi)存中的數(shù)組時(shí),我們應(yīng)該找到其在內(nèi)存中的地址,當(dāng)我們找到數(shù)據(jù)的地址后我們就可以找到對(duì)應(yīng)的數(shù)據(jù)。了解了以上知識(shí)后,我們就可以進(jìn)行數(shù)組的設(shè)計(jì)了(我們就可以設(shè)計(jì)自己的數(shù)組供別人去使用了,哈哈)。
了解了以上知識(shí)后,第一個(gè)問題就來了,如何才能找到數(shù)據(jù)在內(nèi)存中的地址?這個(gè)問題其實(shí)很簡(jiǎn)單,因?yàn)閿?shù)組在內(nèi)存中是一組連續(xù)的數(shù)據(jù)集合,所以我們只要知道數(shù)組首地址,然后通過對(duì)應(yīng)字節(jié)長(zhǎng)度的加減就可以找到對(duì)應(yīng)字節(jié)數(shù)的數(shù)據(jù),有了這些就可以定義出我們的數(shù)組,但是,作為一個(gè)合理的數(shù)組,還應(yīng)該有數(shù)組長(zhǎng)度的標(biāo)志len和數(shù)組有效元素的標(biāo)志cnt。由此給出對(duì)數(shù)組的定義(本例中采用結(jié)構(gòu)體,對(duì)結(jié)構(gòu)體不了解的朋友可以去查一下)
struct Arr { int *pBase; //存儲(chǔ)的是數(shù)組的第一個(gè)元素的地址 int len; //數(shù)組所能容納的最大元素的個(gè)數(shù) int cnt; //數(shù)組有效元素的個(gè)數(shù) };
上述代碼定義了一個(gè)struct Arr的結(jié)構(gòu)體,這個(gè)結(jié)構(gòu)體就是一個(gè)數(shù)組,其中有存儲(chǔ)數(shù)組元素中首地址的成員,有存儲(chǔ)數(shù)組長(zhǎng)度和數(shù)組有效元素個(gè)數(shù)的成員。
有了對(duì)結(jié)構(gòu)體的定義之后,就應(yīng)該涉及到對(duì)數(shù)組的基本操作,包括數(shù)組的初始化,判斷數(shù)組是否為空,對(duì)數(shù)組進(jìn)行顯示,判斷數(shù)組是否已滿,對(duì)數(shù)組的最后追加一個(gè)元素,對(duì)數(shù)組元素的插入。其中,主要的算法就是對(duì)數(shù)組元素的插入,插入算法的核心就是首先應(yīng)該先將被插入及插入位置之后的元素后移,然后將空出來的位置插入我們要插入的元素。一下給出c語言的實(shí)現(xiàn):
/* 數(shù)組初始化函數(shù) 初始化僅僅是給出一個(gè)具有一定長(zhǎng)度的數(shù)組,但是數(shù)組中沒有有效值 */ void init_arr(struct Arr * pArr,int len) { pArr->pBase=(int *)malloc(sizeof(int)*len); if(NULL==pArr->pBase){ printf("動(dòng)態(tài)內(nèi)存分配失敗"); exit(-1); //終止整個(gè)程序 } else{ pArr->len=len; pArr->cnt=0; } } /* 判斷數(shù)組是否為空的函數(shù) */ int is_empty(struct Arr * pArr){ if(pArr->cnt==0){ return 0; //0代表true } else{ return 1; //1代表false } } /* 數(shù)組輸出顯示函數(shù) 在進(jìn)行數(shù)組輸出時(shí),首先應(yīng)該判斷數(shù)組是否為空 */ void show_arr(struct Arr * pArr){ if(is_empty(pArr)==0){ printf("當(dāng)前數(shù)組為空!"); } else{ int i; for(i=0; i<pArr->cnt; ++i){ printf("%d ",pArr->pBase[i]); } printf("\n"); } } /* 判斷數(shù)組是否已滿的函數(shù) */ int is_full(struct Arr * pArr){ if(pArr->cnt==pArr->len){ return 0; //0代表true,表示已滿 } else{ return 1; //1代表false,表示未滿 } } /* 在數(shù)組的最后追加一個(gè)元素 在追加數(shù)組元素前要判斷當(dāng)前數(shù)組是否已滿,已滿時(shí)不允許追加新的元素 */ int append_arr(struct Arr *pArr,int val){ if(is_full(pArr)==0){ return 0; } else{ pArr->pBase[pArr->cnt]=val; pArr->cnt++; return 1; } } /* 在數(shù)組的指定位置插入元素 插入算法:首先將被插入位置的元素全部后移,然后再將空出來的位置插入。 根據(jù)算法原理,所以,在插入的時(shí)候應(yīng)該檢查數(shù)組是否已滿。 上述兩種情況均合理時(shí),進(jìn)行數(shù)據(jù)的插入,插入時(shí),若插入第三個(gè)位置,實(shí)際是將數(shù)據(jù)賦值給arr[pos-1] 注意:再將插入位置后的元素后移時(shí),應(yīng)該從后向前移動(dòng)。否則,將會(huì)造成“被移到”的位置的值被覆蓋 */ int insert_arr(struct Arr *pArr,int pos,int val){ if(is_full(pArr)==0){ return 0; //0表示當(dāng)前數(shù)組已滿,無法再進(jìn)行插入 } //在數(shù)組可插入的情況下,應(yīng)該檢查用戶輸入的pos位置值是否合理 if(pos<0||pos>(pArr->len)){ return 1; //1表示當(dāng)前用戶插入位置不合法 } //移動(dòng)位置 int i; for(i=pArr->cnt -1;i>=pos-1;--i){ pArr->pBase[i+1]=pArr->pBase[i]; } //空缺位置插入元素 pArr->pBase[pos-1]=val; return 2; //2表示當(dāng)前插入成功 }
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
上一篇:有關(guān)C++繼承與友元、繼承與類型轉(zhuǎn)換詳解
欄 目:C語言
下一篇:淺談C++繼承中的名字查找
本文標(biāo)題:C語言 數(shù)據(jù)結(jié)構(gòu)之連續(xù)存儲(chǔ)數(shù)組的算法
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1824.html
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)數(shù)怎么表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置