欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言 數(shù)據(jù)結(jié)構(gòu)之連續(xù)存儲(chǔ)數(shù)組的算法

 更新時(shí)間:2017年01月11日 10:51:16   投稿:lqh  
這篇文章主要介紹了C語(yǔ)言 數(shù)據(jù)結(jié)構(gòu)之連續(xù)存儲(chǔ)數(shù)組的算法的相關(guān)資料,需要的朋友可以參考下

數(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)行尋址的問(wèn)題。首先,先說(shuō)一下在數(shù)組中數(shù)據(jù)是如何存儲(chǔ)的,在內(nèi)存中,數(shù)組中的數(shù)據(jù)是以一組連續(xù)的數(shù)據(jù)集合的形式存在于內(nèi)存中。當(dāng)我們?cè)L問(wèn)存在于內(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è)問(wèn)題就來(lái)了,如何才能找到數(shù)據(jù)在內(nèi)存中的地址?這個(gè)問(wèn)題其實(shí)很簡(jiǎn)單,因?yàn)閿?shù)組在內(nèi)存中是一組連續(xù)的數(shù)據(jù)集合,所以我們只要知道數(shù)組首地址,然后通過(guò)對(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)該先將被插入及插入位置之后的元素后移,然后將空出來(lái)的位置插入我們要插入的元素。一下給出c語(yǔ)言的實(shí)現(xiàn):

/*
數(shù)組初始化函數(shù) 
初始化僅僅是給出一個(gè)具有一定長(zhǎng)度的數(shù)組,但是數(shù)組中沒(méi)有有效值 
*/
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ù)組的指定位置插入元素 
插入算法:首先將被插入位置的元素全部后移,然后再將空出來(lái)的位置插入。
根據(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ù)組已滿,無(wú)法再進(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++實(shí)操之內(nèi)聯(lián)成員函數(shù)介紹

    C++實(shí)操之內(nèi)聯(lián)成員函數(shù)介紹

    大家好,本篇文章主要講的是C++實(shí)操之內(nèi)聯(lián)成員函數(shù)介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • C中的volatile使用方法

    C中的volatile使用方法

    volatile 影響編譯器編譯的結(jié)果,指出,volatile 變量是隨時(shí)可能發(fā)生變化的,與volatile變量有關(guān)的運(yùn)算,不要進(jìn)行編譯優(yōu)化,以免出錯(cuò)
    2013-02-02
  • C語(yǔ)言 操作符分類解析與使用

    C語(yǔ)言 操作符分類解析與使用

    C 語(yǔ)言提供了豐富的操作符,有:算術(shù)操作符,移位操作符,位操作符,邏輯操作符,逗號(hào)表達(dá)式。讓我們通讀本篇來(lái)詳細(xì)了解吧
    2021-11-11
  • C++多態(tài)虛析構(gòu)和純虛析構(gòu)的實(shí)現(xiàn)

    C++多態(tài)虛析構(gòu)和純虛析構(gòu)的實(shí)現(xiàn)

    本文主要介紹了C++多態(tài)虛析構(gòu)和純虛析構(gòu)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-09-09
  • C++實(shí)現(xiàn)俄羅斯方塊源碼

    C++實(shí)現(xiàn)俄羅斯方塊源碼

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)俄羅斯方塊源碼完整版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C++ Boost Intrusive庫(kù)示例精講

    C++ Boost Intrusive庫(kù)示例精講

    Boost是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱。Boost庫(kù)是一個(gè)可移植、提供源代碼的C++庫(kù),作為標(biāo)準(zhǔn)庫(kù)的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開(kāi)發(fā)引擎之一,是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱
    2022-11-11
  • C++面試基礎(chǔ)之static關(guān)鍵字詳解

    C++面試基礎(chǔ)之static關(guān)鍵字詳解

    這篇文章主要給大家介紹了關(guān)于C++面試基礎(chǔ)之static關(guān)鍵字的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • 論C++的lambda是函數(shù)還是對(duì)象

    論C++的lambda是函數(shù)還是對(duì)象

    這篇文章主要介紹了論C++的lambda是函數(shù)還是對(duì)象,對(duì)于有捕獲的lambda,其等價(jià)于對(duì)象。對(duì)于沒(méi)有任何捕獲的lambda,其等價(jià)于函數(shù),下面來(lái)看看具體的相關(guān)內(nèi)容,需要的朋友可以參考一下
    2022-02-02
  • C++ 互斥鎖原理以及實(shí)際使用介紹

    C++ 互斥鎖原理以及實(shí)際使用介紹

    本文主要聊一聊如何使用互斥鎖以及都有哪幾種方式實(shí)現(xiàn)互斥鎖。實(shí)現(xiàn)互斥,可以有以下幾種方式:互斥量(Mutex)、遞歸互斥量(Recursive Mutex)、讀寫鎖(Read-Write Lock)、條件變量(Condition Variable)。感興趣的同學(xué)可以參考一下
    2023-04-04
  • C++控制臺(tái)實(shí)現(xiàn)貪吃蛇游戲

    C++控制臺(tái)實(shí)現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細(xì)介紹了C++控制臺(tái)實(shí)現(xiàn)貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評(píng)論