第三週專案四

2021-07-05 07:38:00 字數 2756 閱讀 8092

問題及**

*all right reserved.

*檔名稱:線性表刪除元素.cpp

*完成日期;2023年9月15日

*版本號;v1.0

* *問題描述:  定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作:

刪除元素在[x, y]之間的所有元素,要求演算法的時間複雜度為o(n),空間複雜度為o(1);

將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o(n),空間複雜度為o(1)。  

*輸入描述:刪除前的資訊

*程式輸出:刪除後的資訊

*/#include #include #define maxsize 50

typedef int elemtype;

typedef struct

sqlist;

void createlist(sqlist *&l, elemtype a, int n);//用陣列建立線性表

void initlist(sqlist *&l);//初始化線性表initlist(l)

void destroylist(sqlist *&l);//銷毀線性表destroylist(l)

bool listempty(sqlist *l);//判定是否為空表listempty(l)

int listlength(sqlist *l);//求線性表的長度listlength(l)

void displist(sqlist *l);//輸出線性表displist(l)

bool getelem(sqlist *l,int i,elemtype &e);//求某個資料元素值getelem(l,i,e)

int locateelem(sqlist *l, elemtype e);//按元素值查詢locateelem(l,e)

bool listinsert(sqlist *&l,int i,elemtype e);//插入資料元素listinsert(l,i,e)

bool listdelete(sqlist *&l,int i,elemtype &e);//刪除資料元素listdelete(l,i,e)#endif // list_h_included

//用陣列建立線性表

void createlist(sqlist *&l, elemtype a, int n)

//初始化線性表initlist(l)

void initlist(sqlist *&l) //引用型指標

//銷毀線性表destroylist(l)

void destroylist(sqlist *&l)

//判定是否為空表listempty(l)

bool listempty(sqlist *l)

//求線性表的長度listlength(l)

int listlength(sqlist *l)

//輸出線性表displist(l)

void displist(sqlist *l)

//求某個資料元素值getelem(l,i,e)

bool getelem(sqlist *l,int i,elemtype &e)

//按元素值查詢locateelem(l,e)

int locateelem(sqlist *l, elemtype e)

//插入資料元素listinsert(l,i,e)

bool listinsert(sqlist *&l,int i,elemtype e)

//刪除資料元素listdelete(l,i,e)

bool listdelete(sqlist *&l,int i,elemtype &e)

void delx2y(sqlist *&l, elemtype x, elemtype y)

for (i=0; ilength; i++)

if (l->data[i]data[i]>y )

l->length=k;

}int main()

; createlist(sq, a, 10);

printf("刪除前 ");

displist(sq);

delx2y(sq, 4, 7);

printf("刪除後 ");

displist(sq);

return 0;

}void move(sqlist *&l)

}  

}int main()

;    createlist(sq, a, 10);

printf("操作前 ");

displist(sq);

move(sq);

printf("操作後 ");

displist(sq);

return 0;

}

執行結果

知識點總結

利用之前多函式檔案總結的演算法表(在此全部合為乙個函式)讓此程式變得不再複雜,建立新變數將x與y進行交換,最後將刪除後的資訊重新排序輸出,這是刪除數字

奇偶數排列則是從右到左和從左到右對奇偶數分別排列,最後當i學習心得

此程式運用了指標引用的方式將資訊進行成功交換,在日後的程式設計中一定要將三種傳值方法運用熟練,避免發生錯誤。

對不奇偶數排列同時進行才能縮短時間,降低時間複雜度。

第三週專案四

1.檔名稱 2.作 者 武美妤 3.完成日期 2017年9月17日 4.版 本 號 v1.0 5.問題描述 定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作 1 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 2 將所在奇數移到所有偶數的前面,要求演...

第三週專案四

煙台大學計算機學院 問題描述 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 輸出描述 刪除後的元素 include list.h include 刪除線性表中,元素值在x到y之間的元素 void delx2y sqlist l,elemtype...

第三週專案四

煙台大學計算機學院 檔名稱 xm1.cpp 完成日期 2017年9月17日 問題描述 順序表建立,查詢 輸入描述 無 輸出描述 順序表元素,順序表位置 include include define maxsize 50 儲存空間大小巨集定義 typedef int elemtype 定義elemty...