第三週專案4 順序表應用(2)

2021-07-22 22:18:38 字數 2845 閱讀 9758

問題及**:

/*      

*檔名稱:111.cbp

*作 者:王曼

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

*版 本 號:v1.0

*

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

*輸入描述:無

*程式輸出:輸出調整後的線性表

*/

標頭檔案list.h**:

#ifndef list_h_included      

#define list_h_included

#define maxsize 50

#include #include 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

#endif

功能檔案函式list.cpp**:

//#include "list.h"      

//用陣列建立線性表

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)

測試檔案main.cpp**:

//#include "list.h"      

//#include //移動結束後,奇數居左,偶數居右

void move(sqlist *&l)

} //待迴圈上去後,繼續查詢,並在必要時交換

}

//用main寫測試**

int main()

;

createlist(sq, a, 12);

printf("操作前 ");

displist(sq);

move(sq);

printf("操作後 ");

displist(sq);

return 0;

}

執行結果

知識總結:主要通過move函式實現操作
學習心得:鞏固了線性鍊錶的查詢替換

第三週專案4 順序表應用(2)

問題與 檔名稱 head.h,main.cpp,zdy.cpp,move.cpp 完成日期 2015年10月5日 版本號 v1.0 問題描述 定義乙個採用順序結構儲存的線性表,將所在 奇數移到所有偶數的前面,要求演算法的時間復 雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 若干資料 in...

第三週。專案4 順序表應用(2)

檔名稱 專案4 順序表應用 2 cpp 作 者 魏樂天 完成日期 2015年10月12日 版 本 號 v1.0 問題描述 定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 若干資料 程式輸出 將資料...

第三週專案4 順序表應用(2)

問題及 檔名稱 111.cbp 作 者 李曉鈺 完成日期 2016年9月17日 版 本 號 v1.0 問題描述 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 輸出調整後的線性表 標頭檔案list.h ifndef list h inc...