問題及**:
/*
* 檔名稱:專案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 ...