亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

線性結構之數組實現

發布時間:2020-07-10 11:22:06 來源:網絡 閱讀:391 作者:qingliangdexiar 欄目:開發技術

#include<stdio.h>

#include<stdlib.h>

typedef struct

{

int *pArr;

int length;//數組最大容量

int cnt;//當前數組有效個數

}SqList;

void init_arr(SqList *,int length);

void destroy_arr();

void remove_arr(SqList *,int,int *);

void append_arr(SqList *,int);

void insert_arr(SqList *,int,int);

void get_arr();

void replace_arr();

void travel_arr(SqList *);

void reverse_arr(SqList *);

void sort_arr(SqList *);

int size();

bool isEmpty(SqList *);

bool isFull(SqList *);

void main()

{

//我們剛開始的時候,這樣寫SqList arr,代替SqList * arr,

//因為這樣的好處是到時候要使用arr變量,可以在此使用*arr,否則沒有余地了。

SqList arr;

//初始化這個線性表。

init_arr(&arr,6);

//遍歷這個線性表。

travel_arr(&arr);

//追加元素到線性表。

printf("開始追加元素到線性表中\n");

append_arr(&arr,2);

append_arr(&arr,4);

append_arr(&arr,0);

//遍歷這個線性表

travel_arr(&arr);

//插入元素到線性表

insert_arr(&arr,1,3);

//遍歷這個線性表

travel_arr(&arr);

//刪除元素

int val;

remove_arr(&arr,2,&val);

//遍歷這個線性表

travel_arr(&arr);

//倒置這個線性表

reverse_arr(&arr);

//遍歷這個線性表

travel_arr(&arr);

printf("開始排序\n");

//排序這個線性表

sort_arr(&arr);

//遍歷這個線性表

travel_arr(&arr);


}

void init_arr(SqList *arr,int length)

{

arr->pArr=(int *)malloc(sizeof(int)*length);

if(NULL==arr->pArr)

{

printf("動態內存分配失敗");

exit(-1);

}

else

{

arr->length=length;

arr->cnt=0;

}

}

bool isEmpty(SqList *arr)

{

if(arr->cnt==0)

return true;

else

return false;

}

void travel_arr(SqList * arr)

{

//判斷現行表是否為空,提示用戶線性表為空

if(isEmpty(arr))

printf("當前線性表為空");

else

{

//遍歷線性表

for(int i=0;i<arr->cnt;i++)

printf("%d ",arr->pArr[i]);

printf("\n");

}

}

void append_arr(SqList *arr,int temp)

{

if(isFull(arr))

{

printf("線性表已滿,無法再繼續追加");

}

else

{

arr->pArr[arr->cnt]=temp;

arr->cnt++;

}


}

bool isFull(SqList *arr)

{

if(arr->cnt==arr->length)

return true;

else

return false;

}

//pos代指下標

void insert_arr(SqList *arr,int pos,int temp)

{

if(isFull(arr))

{

printf("線性表已滿,無法插入");

}

else

{

for(int i=arr->cnt-1;i>=pos;i--)

{

arr->pArr[i+1]=arr->pArr[i];

}

arr->pArr[pos]=temp;

arr->cnt++;

}

}

void remove_arr(SqList *arr,int pos,int *val)

{

if(isEmpty(arr))

{

printf("線性表中元素為空,沒有元素");

}

else

{

*val=arr->pArr[pos];

for(int i=pos;i<arr->cnt-1;i++)

{

arr->pArr[i]=arr->pArr[i+1];

}


arr->cnt--;

}

}

//對稱,找到中間的合適的中間點,置換下,即可。一般通過這個線性表的總長度/2來算合適的中間點。

//這個算法可能不太合適。

void reverse_arr(SqList *arr)

{

if(isEmpty(arr))

{

printf("線性表為空,不會產生倒置");

}

else

{

/*

int temp;

for(int i=0;i<arr->cnt/2;i++)

{

temp=arr->pArr[arr->cnt-1-i];

arr->pArr[arr->cnt-1-i]=arr->pArr[i];

arr->pArr[i]=temp;

}

*/

int temp;

int i=0;

int j=arr->cnt-1;

while(i<j)

{

temp=arr->pArr[j];

arr->pArr[j]=arr->pArr[i];

arr->pArr[i]=temp;

i++;

j--;

}

}

}

//冒泡排序

void sort_arr(SqList *arr)

{

int temp;

for(int i=0;i<arr->cnt-1;i++)

for(int j=0;j<arr->cnt-1-i;j++)

if(arr->pArr[j]>arr->pArr[j+1])

{

temp=arr->pArr[j+1];

arr->pArr[j+1]=arr->pArr[j];

arr->pArr[j]=temp;

}


}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

左云县| 常山县| 德惠市| 神池县| 房产| 陆丰市| 兴城市| 临洮县| 阳西县| 绥棱县| 和平县| 定日县| 法库县| 辰溪县| 崇州市| 措美县| 盘山县| 怀仁县| 黄骅市| 霍州市| 巢湖市| 凌源市| 偏关县| 油尖旺区| 房产| 正安县| 湟源县| 赫章县| 农安县| 清镇市| 信阳市| 哈尔滨市| 贡觉县| 扶沟县| 峨边| 普格县| 平顺县| 涡阳县| 香格里拉县| 大石桥市| 宜章县|