```
/************************************************************************
*
* 程序名字: Sq_list.c
* 作 者: sid_tapole
* 版 本: 1.0.1
* 編寫時間: 2015年6月
* 功 能: 鏈表==>增刪改查、分支合并
*
*************************************************************************/
#define INIT_SIZE_LIST 100 // 線性表初始空間分配量
#define INCREAMENT_LIST 10 // 線性表的分配增量
#define ELEM_TYPE int // 自定義類型
#define STATUS int // 自定義的類型
typedef struct {
ELEM_TYPE *elem; // 線性表基址
int length; // 當前長度
int list_size; // 當前分配的存儲容量ELEM_TYPE
} Sq_list;
Sq_list L;
/***************************************************** init_list_Sq BEGIN
*
* init_list_Sq 初始化鏈表
*
* @param
* &L 哨兵節點
* @return
* STATUS 捕獲程序運行狀態
*/
STATUS init_list_Sq(Sq_list &L)
{
// 構造一個空的線性表L
L.elem = (ELEM_TYPE *)malloc(INIT_SIZE_LIST * sizeof(ELEM_TYPE));
if (!L.elem) {
printf("分配空間失敗!程序異常退出!");
exit(-1);
}
L.length = 0; // 空表長度為0
L.list_size = INIT_SIZE_LIST; // 初始存儲容量
return 0;
}
//------------------------------------------------------ init_list_Sq END
/**************************************************** insert_list_Sq BEGIN
*
* init_list_Sq 插入節點
*
* @param
* &L 哨兵節點
* @param
* i 第i個節點
* @param
* e 類型
* @return
* STATUS 捕獲程序運行狀態
*/
STATUS insert_list_Sq(Sq_list &L, int i, ELEM_TYPE e)
{
ELEM_TYPE *newbase = NULL;
ELEM_TYPE *q, *p;
/*
** 在順序線性表L中第i個位置之前插入新的元素e,
** i的合法值為 1<= i <=list_length_Sq(L) + 1
** i 不合法,錯誤退出-1
*/
if (i < 1 || i > L.length + 1) {
return -1;
}
//當前存儲空間已滿,增加分配
if (L.length >= L.list_size) {
newbase = (ELEM_TYPE *)realoc(L.elem,
(L.list_size + INCREAMENT_LIST) * sizeof(ELEM_TYPE));
if (!newbase){
printf("分配空間失敗!程序異常退出!");
exit(-1);
}
L.elem = newbase; // 新基址
L.list_size += INCREAMENT_LIST; // 增加存儲容量
}
q = &(L.elem[i -1]); // q為插入位置
for (p = &(L.elem[L.length -1]); p >= q; --p) {
//插入位置及之后的元素右移
*(p + 1) = *p;
}
*q = e; // 插入e
++L.length; // 表長增1
return 0;
}
//----------------------------------------------------- insert_list_Sq end
/**************************************************** delete_list_Sq BEGIN
*
* delete_list_Sq 刪除節點
*
* @param
* &L 哨兵節點
* @param
* i 第i個節點
* @param
* e 類型
* @return
* STATUS 捕獲程序運行狀態
*/
STATUS delete_list_Sq(Sq_list &L, int i, ELEM_TYPE &e)
{
ELEM_TYPE *p,*q;
/*
** 在順序線性表L中刪除第i個元素,并用e返回其值
** i的合法值為 1<= i <=list_length_Sq(L)
** i 不合法,錯誤退出-1
*/
if (i < 1 || i > L.length) {
exit (-1);
}
p = &(L.elem[i - 1]); // p為刪除元素的位置
e = *p; // 被刪除元素的值賦給e
q = L.elem + L.length - 1; // 表尾元素的位置
for (++p; p <= q; ++p) {
//被刪除元素之后的元素左移
*(p - 1) = *p;
}
--L.length; // 表長減1
return 0;
}
//----------------------------------------------------- delete_list_Sq end
/***************************************************** local_list_Sq BEGIN
*
* local_list_Sq 查找
*
* @param
* &L 哨兵節點
* @param
* e 類型
* @param
* STATUS 常量
* @return
* STATUS 捕獲程序運行狀態
*/
STATUS local_list_Sq(Sq_list &L, ELEM_TYPE e, STATUS (*compare)(ELEM_TYPE,ELEM_TYPE))
{
/*
** 在順序線性表L中查找第1個值與e滿足compare()的元素的位序
** 若找到,則返回其在L中的位序,否則返回0
*/
int i = 1; // i的初值為第一個元素的位序
ELEM_TYPE *p = L.elem; // p的初值為第一個元素的存儲位置
while (i <= L.length && !(*compare)(*p++, e)) {
i++;
}
if (i <= L.length) {
return i;
}
else {
return 0;
}
}
//----------------------------------------------------- local_list_Sq end
/***************************************************** merge_list_Sq BEGIN
*
* local_list_Sq 合并分支鏈表
*
* @param
* La 鏈表A
* @param
* Lb 鏈表B
* @param
* &Lc 鏈表C哨兵
* @return
* STATUS 捕獲程序運行狀態
*/
STATUS merge_list_Sq(Sq_list La, Sq_list Lb, Sq_list &Lc)
{
/*
** 已知順序線性表La和Lb的元素按值非遞減排列
** 歸并La和Lb得到新的線性表Lc,它的數據元素也按值非遞減排列。
*/
ELEM_TYPE *pa_last, *pb_last, *pc, *pa, *pb;
pa = La.elem;
pb = Lb.elem;
Lc.list_size = Lc.length = La.length + Lb.length;
pc = Lc.elem = (ELEM_TYPE *)malloc(Lc.list_size*sizeof(ELEM_TYPE));
if (!Lc.elem) {
printf("分配空間失敗!程序異常退出!");
exit(-1);
}
pa_last = La.elem + La.length - 1;
pb_last = Lb.elem + Lb.length - 1;
while (pa <= pa_last && pb <= pb_last) { // 歸并
if (*pa <= *pb) {
*pc++ = *pa++;
}
else {
*pc++ = *pb++;
}
}
while (pa <= pa_last) {
*pc++ = *pa++; // 插入La的剩余元素
}
while (pb <= pb_last) {
*pc++ = *pb++; // 插入La的剩余元素
}
return 0;
}
//----------------------------------------------------- merge_list_Sq end
```
- 2023-4-8__成長之路
- 技術雜談
- 程序員境界
- 走進猿類
- 做一個程序員
- 什么是猿類
- 愛亂吹的猿
- 業余生活
- 我的書架
- 高效程序員的45個習慣
- 敏捷—高效軟件開發之道
- 態度決定一切
- 學無止盡
- 交付用戶想要的軟件
- 敏捷反饋
- 敏捷編碼
- 敏捷調試
- 藝術人生
- 摘自藝術的境界
- 如何欣賞畫
- 《的》
- 我的文檔
- 小白學習前那些說不完的事
- 計算機語言都一樣
- 嘗試理解他人代碼
- 做為旁觀者的思考
- 怎樣才算懂計算機
- 工欲善其事,必先利其器
- 教案日志
- 十天學電腦
- 一,認識計算機
- 二、認識編程語言
- 三、認識程序內涵
- 四,認識數據結構
- 五、認識電腦系統
- 六、認識通信原理
- 七、郵箱管理
- 八、重新審視電腦
- 九、理解終生學習
- 十、感悟三千世界
- c語言
- C語言——我覺得好簡單
- c學好不怕沒飯碗—2014.7.21
- C語言——我想的有點兒簡單
- 或多或少的c語言知識
- c語言初探篇
- 初探c語言底層
- 初探整型和浮點型
- 初探二進制數---原反補移
- 初探有無符號
- 初探c是如何跑起來的
- 初探指針
- 初探數組
- 初探順序表
- 初探棧,隊列
- 初探c語言編程
- c語言進階篇
- c語言自身的那些事
- 結構詳解
- c語言大成篇
- 人類思維——模式匹配
- 論c語言面試
- 數據結構
- 核心概念,沒有之一順序表
- 線性表代碼實現
- Sq_list
- 不存在的鏈表
- 只是一種思想——棧
- 只是一種思想——隊列
- 不存在的樹
- 只是一種思想——二分法
- 不存在的圖
- 算法原理
- 傅里葉變換
- 算法導論
- 算法導論——c語言實現
- 算法導論——java實現
- 組成原理
- 操作系統
- 初探操作系統
- 深究操作系統
- 操作系統如何跑起來
- 進程就像細胞
- 系統就像生命
- 進程樹pstree
- 進程
- 進程何時更名為生命
- 初探進程映像
- 程序如何成為進程映像
- PCB
- PCB解讀之——信號量(p_sig)
- 進程同步
- 進程通信
- 進程調度
- 用戶
- PPDA
- 存儲系統
- I/O系統
- 網絡原理
- 通信簡史
- 通信是網絡基礎
- 趣談網絡
- 自我介紹
- 快遞公司
- 小D的自述
- 網絡架構
- OSI/RM
- 應用層
- 表示層
- 會話層
- 傳輸層
- 網絡層
- 數據鏈路層
- 物理層
- TCP/IP四層模型
- 五層模型
- 網絡劃分
- IP史
- 信息安全
- 社會工程學
- 信息收集
- 誘導
- 偽裝
- 如何成為任何人
- 社會心理學
- 思維模式
- 說服的力量
- 代碼審計
- 災難恢復
- 安全注入
- 網絡工程
- 802.11
- CCNA
- CWNA
- 社會工程
- 社會心理
- 信息誘導
- 身份偽裝
- 系統框架
- web前端框架
- smarty框架
- bootstrap框架
- thinkphp框架
- zend框架
- yii框架
- ci框架
- 網站開發
- 五大難題
- 網站工作原理
- 數據庫原理
- 服務器原理
- 前端開發
- 前端技能基礎
- html
- css
- javascript
- 瀏覽器兼容
- 前端總結
- 后臺開發
- 或多或少的JS
- js初探篇
- 理解Javascript
- JS繼承
- 數組
- 操作方法
- DOM事件
- 數據傳輸
- JS面試題
- 數據對象
- 學生管理系統
- 學生管理首頁
- 粗略學了一遍后的總結
- 零碎知識
- js初探篇第二版
- javascript構成
- 基本類型
- 基本語句與判斷類型
- 基本對象與操作函數
- 基本判斷與甄別數據
- 內置對象與操作函數
- 對象認識與深淺復制
- DOM級別與BOM
- 嚴格模式與混雜模式
- ES5和ES6
- js進階篇
- 上傳圖片
- js實戰篇
- 或多或少的PHP
- 詳解url結構
- html基礎
- html初識
- html-組成頁面的基礎標簽
- ie兼容
- 教學方法
- 論php——編程思想
- 論php——底層實現
- 中華國學
- 易經
- 黃帝內經
- 山海經
- 道德經
- 騙經
- 中華哲學
- 一花一世界
- 道可道非常道
- 一瞬
- 宇宙
- 心得體會
- 電腦叫智能生命體更準確
- 計算機不是漢語模式
- 瑣事日記
- 成長與人性
- 祝單身狗快樂
- 人其實過的很單薄
- 都怪自己不夠優秀
- 那是幾個人的世界
- 認清世界,認清自己
- 陪伴繁華逝去的平凡
- 俯拾仰取
- 技術手冊
- 網站開發
- 準備工作
- firewalld
- mysql
- redis
- 開發流程
- 整體配置
- 環境配置
- tomcat配置
- 數字證書配置
- 項目配置
- 數據設計
- 用戶管理
- 整站設計
- user
- user_group
- user_role
- 服務端
- 了解學習
- quartz
- HelloWorld
- HelloJob
- HelloQuartz
- HelloScheduler
- Job
- JobDataMap
- Trigger
- Scheduler
- properties
- spring
- AOP
- 使用
- svnkit
- svn init
- FSFS
- server
- Java
- 測試
- 任務調度
- 網站架構
- 網站前端
- pc端
- 移動端
- native
- ios
- android
- ipad
- hybrid
- 技術日志
- 2018-9-26
- 2018-11-26
- 資源收集
- UED資源
- 技術架構
- 云平臺
- 工作方面
- 實習工作經驗
- 草稿1
- 草稿2
- 草稿3
- 草稿4
- 草稿5
- 草稿6
- 草稿7
- 大學總結
- 面經
- 一、職能定位
- 細節
- 前端
- 工作總結
- 簡歷
- 職業規劃
- 一年規劃
- 整理歸檔
- 2015/11/10以前
- 2015/11/10
- 2015/11/11
- 2015/11/12
- 2015/11/13
- 2015/11/14
- 2015/11/15與16
- 2015/11/17
- 2015/11/18
- 2015/11/19與20
- 2015/11/21
- 2015/11/22
- 2015/11/23
- 2015/11/24
- 2015/11/25
- 2015/11/26
- 2015/11/27
- 2015/11/28
- 2015/11/29
- 2015/11/30-12/6
- 2015/12/7-2016/4/18
- 2016/4/19
- 2016/4/20~2017/6/27
- 2017/6/28-2017/7/4
- 2017/7/5-2018/1/11
- 2018/1/12
- 2018/1/13-2018/4/19
- 2018/4/20
- 2018/4/21-2018/5/10
- 2018/5/11
- 2018/5/12-2018/5/16
- 2018/5/17-2018/5/30
- 2018/5/30-2018/10/15
- 2018/10/15-2018/10/18
- 2018/10/19-2018/11/17
- 2018/11/17-2018/12/31
- 結束----------------開始
- 2019/2/18
- 2020/7/30
- 2020/9/5
- 2021/5/6
- 回收站
- 以前文件
- 2015-10-17__成長之路
- 2018-10-15__成長之路
- 2020-3-29__成長之路
- 畢業三年總結
- 浙大之旅
- 2020
- 英語
- 基礎3000單詞
- 第一周
- 百詞斬__126
- 百詞斬__126翻譯
- 百詞斬__252
- 百詞斬_252翻譯
- 百詞斬__392
- 百詞斬__532
- 百詞斬__672
- 第二周
- 百詞斬__812
- 聽力
- 新東方演講稿
- 庫克杜克大學演講全文版
- 庫克杜克大學演講演講英文對照版