#include//輸入輸出函式標頭檔案
#include//記憶體申請函式標頭檔案
#define list_init_size 100
#define listincrement 10
typedef int elemtype ;
typedef struct
sqlist ;
//操作結構,構造乙個空的線性表l
void initlist( sqlist& l )
//將此時線性表的大小初始化為0
l.length = 0 ;
//將此線性表的剩餘空間置為最大
l.listsize = list_init_size ;
}//初始條件:線性表l已經存在
//操作結果,銷毀線性表l
//初始條件:線性表l已經存在
//操作結果:將l重置為空表
void clearlist ( sqlist& l)
//初始條件:線性表l以存在
//操作結果:若l為空表,則返回true,否則返回false
int listempty ( sqlist l )
void destroylist ( sqlist& l )
//初始條件:la和lb都存在
//操作結果:將la和lb中值,插入到lc中
void mergelist( sqlist& la , sqlist& lb , sqlist& lc )
else}}
else
else
}while( la < la.length )
while( lb2 < lb.length )
}}int main ()
for( n.length = 1 ; n.length < 10 ; n.length ++ )
mergelist( m , n , p ) ;
int m = 1;
for ( ; m < m.length ; m ++ )
int n = 1;
for ( ; n < n.length ; n ++ )
int x = 1;
for ( ; x <= p.length ; x ++ )
clearlist ( m ) ;
clearlist ( n ) ;
clearlist ( p ) ;
destroylist ( m ) ;
destroylist ( n ) ;
destroylist ( p ) ;
return 0 ;
}
重學資料結構與演算法(15 19)
我們前面學習的資料結構和演算法思維,是解決問題和 優化的基礎。本節課開始,我們進入實戰模組,從真正解決問題的角度來看看,如何將我們此前學到的知識靈活運用到實際工作中。加入我現在面對乙個實際的演算法題,我需要從以下兩個方面進行思考。首先,我們要明確目標。即用盡可能低的時間複雜度和空間複雜度,解決問題並...
重學資料結構之第二章 演算法
4 演算法設計的要求 5 演算法效率的度量方法 6 函式的漸近增長 7 演算法的複雜度 8 推到大o階的方法 演算法是解決特定問題求解步驟的描述,在計算機中表現為指令的有限序列,並且每條指令表示乙個或多個操作。舉個例子,求1 2 3 100之和,我們來看兩段 片段1 int sum 0,n 100 ...
重學資料結構系列之 雜湊表
1.定義 雜湊表,也叫雜湊表。根據關鍵碼值 key value 而直接進行訪問的資料結構。比如你要查a,通過雜湊函式f a k就可以得到雜湊表b的索引,b k 即可獲取a 對應的value 這個可以用來快速查重吧,就是你給我乙個a,a在不在雜湊表裡呢?大家平時註冊的時候,使用者大的時候就可以用這個來...