2、將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o(n),空間複雜度為o(1)。
list.h
#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
list.cpp
#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)
main.cpp
#include "list.h"
#include //移動結束後,奇數居左,偶數居右
void move(sqlist *&l)
} //待迴圈上去後,繼續查詢,並在必要時交換
}//用main寫測試**
int main()
; createlist(sq, a, 10);
printf("操作前 ");
displist(sq);
move(sq);
printf("操作後 ");
順序表應用(2)
檔名稱 main.cpp,list.cpp,list.h 完成日期 2015年9月18日 版本號 vc 6.0 問題描述 將奇數移到偶數前面並且保證時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 移完後的結果 include include define maxsize 50 typ...
第三週 順序表應用2
all right reserved.date 2015年9月16日 版本 v1.0.1 作業系統 xp 執行環境 vc6.0 問題描述 定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 1.充分利用前面建立...
實驗2 順序表的應用(集合運算)
實驗內容 1 建立乙個空的集合 2 從陣列元素建立集合 3 查詢集合中是否存在元素x 4 往集合中增加元素x 未做 5 刪除集合的元素x 未做 6 求兩個集合的並集 7 求兩個集合的交集 8 輸出集合。get到的知識點 1.對於下面這種定義順序表的方式,若主函式中直接定義了乙個set set 則不再...