連續存儲數組(C語言)

# include <stdio.h>
# include <malloc.h>
# include <stdlib.h>

//定義數組結構體
struct arr
{
    int  * pBase;  //數組首地址(數組名)
    int  len;  //數組長度
    int  cnt;  //有效數組長度
};


//初始化數組
void init(struct arr * pArr,int length);
//遍歷數組中元素
void show(struct arr * pArr);
//添加一個數組元素
bool add(struct arr * pArr,int val);
//判斷數組元素是否為空數組
bool is_empty(struct arr * pArr);
//判斷數組元素是否是滿的
bool is_full(struct arr * pArr);
//插入數組元素,指定位置
bool add_index(struct arr * pArr,int index,int val);
//倒置數組元素
void reverse(struct arr * pArr);
//刪除特定位置的元素
bool delete_index(struct arr * pArr,int index);
//數組排序 
void sort(struct arr * pArr);
//獲取特定位置元素
int get(struct arr * pArr,int index);


int main(void)
{
    struct arr array;
    printf("---------------------初始化數組--------------------\n");
    init(&array,5);
    show(&array);
    printf("---------------------初始化數組--------------------\n\n\n");

    printf("--------------添加數組元素數組--------------------\n");
    add(&array,1);
    add(&array,2);
    add(&array,3);
    add(&array,4);
    show(&array);
    printf("--------------添加數組元素數組--------------------\n\n\n");
    
    printf("--------------指定位置插入數組元素數組-------------\n");
    add_index(&array,2,5);
    show(&array);
    printf("--------------指定位置插入數組元素數組-------------\n\n\n");

    printf("---------------------刪除數組元素--------------------\n");
    if(delete_index(&array,2)){
        printf("刪除成功\n");
        show(&array);
    }else{
        printf("刪除失敗\n");
    }
    printf("---------------------刪除數組元素--------------------\n\n\n");
    
    printf("---------------------倒置數組元素--------------------\n");
    reverse(&array);
    show(&array);
    printf("---------------------倒置數組元素--------------------\n\n\n");

    printf("---------------------升序數組元素--------------------\n");
    sort(&array);
    show(&array);
    printf("---------------------升序數組元素--------------------\n\n\n");

    printf("---------------------獲取數組元素指定元素--------------------\n");
    int t = get(&array,3);
    if(t == -1){
        printf("無法獲取 \n");
    }else{
        printf("%d \n",t);
    }
    printf("---------------------獲取數組元素指定元素--------------------\n\n\n");
    
    return 0;
}

void init(struct arr * pArr,int length)
{
    pArr->pBase = (int *) malloc(sizeof(int) * length);  //動態開辟空間
    if(NULL == pArr->pBase)
    {
        printf("動態分配內存空間失敗");
        exit(-1);
    }else{
        pArr->len = length;
        pArr->cnt =0;
    }
    return;
}

bool is_empty(struct arr * pArr)
{
    if(pArr->cnt == 0)
    {
        return true;
    }else{
        return false;
    }
}

bool is_full(struct arr * pArr)
{
    if(pArr->cnt == pArr->len)
    {  //數組有效長度和數組開辟空間相等
        return true;
    }else{
        return false;
    }
}

void show(struct arr * pArr)
{
    if(is_empty(pArr))
    {
        printf("數組為空\n");
    }else{
        for(int i =0; i < pArr->cnt;i++)
        {
            printf("%d \n",  pArr->pBase[i]);
        }
    }
}

bool add(struct arr * pArr, int val)
{
    //若是滿的就不再添加
    if(is_full(pArr))
    {
        return false;
    }

    //添加元素
    pArr->pBase[pArr->cnt] = val;
    (pArr->cnt)++;

        return true;
    }

bool add_index(struct arr * pArr, int index, int val)
{
    //若是滿的就不再添加
    if(is_full(pArr))
    {
        return false;
    }
    //若是不在范圍內
    if(index <1 || index >= pArr->cnt)
    {
        return false;
    }

    for(int i = pArr->cnt+1; i >= index-1;i--){   //從插入的位置開始,到結束  從最后一個開始
        pArr->pBase[i+1] = pArr->pBase[i];
    }

    //插入位置
    pArr->pBase[index-1] = val;

    return true;
}

void reverse(struct arr * pArr)
{
    int i = 0;
    int j = pArr->cnt-1;
    int temp;

    while(i < j)
    {
        temp = pArr->pBase[i];    //第一個位置存起來
        pArr->pBase[i] = pArr->pBase[j]; //然后第一個位置存最后一個位置的數
        pArr->pBase[j] = temp;  //最后一個位置存一個位置的數
        i++;
        j--;
    }
    return;
}

bool delete_index(struct arr * pArr,int index)
{
    //若是為空不刪除
    if(is_empty(pArr))
    {
        return false;
    }
    //若是不在范圍內
    if(index <1 || index >= pArr->cnt)
    {
        return false;
    }
    
    for(int i = index;i<pArr->cnt;i++){
        pArr->pBase[i-1] = pArr->pBase[i];  //后面的值賦值到前面
    }
    
    (pArr->cnt)--;
    return true;
}

void sort(struct arr * pArr)
{   
    int temp,i,j;

    for(i = 0; i< pArr->cnt;i++)
    {
        for(j = i+1; j< pArr->cnt;j++)
        {
            if(pArr->pBase[i] > pArr->pBase[j])
            {
                temp = pArr->pBase[i];
                pArr->pBase[i] = pArr->pBase[j];
                pArr->pBase[j] = temp;
            }
        }
    }
}

int get(struct arr * pArr,int index)
{
    //若是為空
    if(is_empty(pArr))
    {
        return -1;
    }
    //若是不在范圍內
    if(index <1 || index >= pArr->cnt)
    {
        return -1;
    }
    return pArr->pBase[index];

}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評論 6 541
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,312評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,993評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,667評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,410評論 6 411
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,778評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,955評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,521評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,266評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,468評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,696評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,095評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,385評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,193評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,431評論 2 378

推薦閱讀更多精彩內容