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

2021-07-22 18:36:26 字數 2699 閱讀 5665

/*    

*檔名稱:專案4.cbp    

*作    者:孟琪琪    

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

*版 本 號:v1.0    

*    

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

*輸入描述:無    

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

*/    

標頭檔案list.h**:

[cpp] view plain copy

#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**:

[cpp] view plain copy

#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測試檔案**:

[cpp] view plain copy

#include "list.h"  

#include //刪除線性表中,元素值在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, 12);  

printf("刪除前 ");  

displist(sq);  

delx2y(sq, 1, 5);//主要運用此函式刪除  

printf("刪除後 ");  

知識點總結:此專案考察了我們對演算法庫的應用。

學習心得:應用的多了,自然而然就掌握了技巧。

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

檔名稱 h1.cpp 完成日期 2015年9月17日 版本號 vc6.0 問題描述 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 線性表的結果 include include define maxsize 50 typedef int...

第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 輸入描述 若干資料 程式輸出 刪除元素後的線性表。演算法...