線性結構之數組實現

#include<stdio.h>算法

#include<stdlib.h>數組

typedef structapp

{ide

int *pArr;spa

int length;//數組最大容量排序

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

}SqList;rem

void init_arr(SqList *,int length);get

void destroy_arr();it

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;

}


}

相關文章
相關標籤/搜索