第3周專案4 2 順序表應用

2021-08-08 12:17:18 字數 2672 閱讀 2081

/*

* 檔名稱:cpp1.

* 作 者:薛瑞琪

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

* 版 本 號:v1.0

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

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

* 輸入描述:無需輸入

* 程式輸出:1.建表的結果

2.移動元素後線性表的結果

*/

#include "list.h"

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

void move(sqlist *&l)

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

}//用main寫測試**

int main()

; createlist(sq, a, 10);

printf("操作前 ");

displist(sq);

move(sq);

printf("操作後 ");

displist(sq);

return 0;

}

#ifndef list_h_included

#define list_h_included

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

#endif // list_h_included

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

執行結果:

知識點總結:

採用程式的多檔案組織形式。利用演算法庫,在程式頭部直接加 #include即可

實現move函式外,呼叫move進行測試和演示。

演算法庫包括兩個檔案: 

標頭檔案:list.h,包含定義順序表資料結構的**、巨集定義、要實現演算法的函式的宣告; 

原始檔:list.cpp,包含實現各種演算法的函式的定義 

學習心得:

雖然**是copy來的,但是如老師所說抄亦有道,節省時間的同時,加強對**的理解和運用。

鞏固了之前所學的程式的多檔案組織形式,跟之前相比使用起來更得心應手。

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

問題及 檔名稱 cpp1.作 者 宋昊 完成日期 2017 年 9 月 20 日 版 本 號 v1.0 問題描述 定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 程式輸出 1.建表的結果 2.刪除元素...

第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 順序表應用(2)

檔名稱 h1.cpp 完成日期 2015年9月18日 版本號 vc6.0 問題描述 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 線性表的結果 include include define maxsize 50 typedef int el...