第三週專案四 順序表的應用1

2021-07-22 17:56:22 字數 2652 閱讀 8121

問題及**:

/*  

* 檔名稱:專案4.cpp

* 作 者:陳迪

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

* 版 本 號:v1.0

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

*輸入描述:無

*程式輸出:刪除後的線性表

*/

標頭檔案list.h:

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

原始檔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 //刪除線性表中,元素值在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;

}

執行結果:

知識點總結:

利用演算法庫解決實際問題

學習心得:

以後要熟練的運用演算法庫

第三週專案四(1) 順序表應用

問題及 all right reserved.檔名 main.cpp list.h list.cpp 完成日期 2017年9月20日 版本號 v1.0 問題描述 刪除元素 輸入描述 無 程式輸出 見視窗 include list.h include 刪除線性表中,元素值在x到y之間的元素 void ...

第三週 專案四 順序表應用 1

問題及 檔名 main.cpp 作 者 王效傑 問題描述 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 完成日期 2017年 9月21日 第三週 課後上機實踐專案4.1 include list.h include include using namespa...

第三週 專案四 順序表的應用1

作 者 蘇凱祺 完成日期 2014年10月19號 版 本 號 v1.0 問題描述 刪除元素在 x,y 數字 之間所有的元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 include list.h include list.cpp void delx2y sqlist l,elemtype ...