第三週 專案四 順序表應用

2021-07-22 18:58:34 字數 3281 閱讀 8364

問題描述及**:

/*   

*完成日期:2016.9.17

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

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

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

*/

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

(1) list.h的**

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

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

(2)list.cpp中的**

#include"list.h"  

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;

}

//用陣列建立線性表

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)

(3)main.cpp的**

#include"list.h"  

int main()

; createlist(sq, a, 10);

printf("刪除前 ");

displist(sq);

delx2y(sq, 4, 7);

printf("刪除後 ");

displist(sq);

return 0;

}

執行結果:

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

(1)move.cpp中的**

#include"list.h"  

void move(sqlist *&l)

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

}

(2)main.cpp的**

#include"list.h"  

int main()

; createlist(sq, a, 10);

printf("操作前 ");

displist(sq);

move(sq);

printf("操作後 ");

displist(sq);

return 0;

}

執行結果:

知識點總結:

利用程庫的多檔案組織讓此程式變得不再複雜,建立新變數將x與y進行交換,最後將刪除後的資訊重新排序輸出,這是刪除數字

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

終於知道上乙個建工程的程式為什麼老是有錯了!!!原來標頭檔案只能放函式的宣告啊!!!

這兩個演算法看懂了,但總覺得稀里糊塗的,還是需要多加練習啊...

第三週 專案四 順序表應用

檔名稱 aa.cpp 完成日期 2016年9月13日 版本號 v1.0 問題描述 定義乙個採用順序結構儲存的線性表,刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 線性表長度 線性表元素及刪除區間 x.y 程式輸出 刪除後的元素 main.cpp i...

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

作 者 蘇凱祺 完成日期 2014年10月20號 版 本 號 v1.0 問題描述 將所有的奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 include list.h include 移動結束後,奇數居左,偶數居右 void move sqlist l 待迴圈上去後,繼續...

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

檔名稱 專案4.cpp 作 者 高金豔 完成日期 2016年9月14日 版 本 號 v1.0 問題描述 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 重新排列後的線性表 標頭檔案list.h define maxsize 50 includ...