第3周專案4 順序表應用(1)

2021-07-05 08:51:24 字數 1334 閱讀 8347

* 檔名稱:h1.cpp

* 完成日期:2023年9月17日

* 版本號:vc6.0

* 問題描述:刪除元素在[x, y]之間的所有元素,要求演算法的時間複雜度為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 displist(sqlist *l);//輸出線性表displist(l)

//用陣列建立線性表

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

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

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

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

bool listempty(sqlist *l)

//輸出線性表displist(l)

void displist(sqlist *l)

//刪除線性表中,元素值在x到y之間的元素

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

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

if (l->data[i]data[i]>y )  //複製不在[x, y]之間的元素

l->length=k;

}//用main寫測試**

int main()

;createlist(sq, a, 10);

printf("刪除前 ");

displist(sq);

delx2y(sq, 4, 7);

printf("刪除後 ");

displist(sq);

return 0;

}執行結果:

知識點總結:充分利用前面建立的演算法庫解決建立順序表、輸出線性表的問題,用迴圈賦值的方式輸出結果。

學習心得:很多知識是靠平時積累總結出來的,比如本次程式所用的知識點包括c++裡的數值交換順序。

第3周 專案4 順序表應用(1)

檔名稱 專案4.cbp 作 者 畢夢楠 完成日期 2015年9月25日 版 本 號 v1.0 問題描述 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 輸出調整後的線性表 ifndef list h included define li...

第3周 專案4 順序表應用(1)

檔名稱 專案3 求集合並集.cpp 作 者 滕健 完成日期 2016年9月15日 問題描述 定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作 1 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 若干資料 程式輸出 刪除元素後的線性表。演算法...

第3周專案4 順序表應用(1)

檔名稱 專案4.cbp 作 者 孟琪琪 完成日期 2016年9月16日 版 本 號 v1.0 問題描述 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 輸出調整後的線性表 標頭檔案list.h cpp view plain copy i...