雙鏈表實現

以前寫的不帶頭的單鏈表實現,當時也啥也沒學,好多東西不知道,加上一心想壓縮代碼,減少情況,所以寫得不太好。

請教了老師,首先是命名問題和代碼緊湊性等的改進。還有可讀性方面的改進,多寫了一些注釋。并且因為帶頭的比較好寫,好操作,所以標準寫法也不是很長,繁瑣。

?

?

下面貼代碼

#include <stdio.h>
#include <stdlib.h>
#include <string.h>typedef struct node{int key;//數據struct node * prev;//前驅struct node * next;//后繼
}Node;

初始化(帶頭)?

Node * list;
//初始化,這里·我們list不再是NULL,而是指向了一個節點
//這個改進方便了很多操作,也不用借助二重指針把list和next統一表示了void init(Node * list)//初始化
{list = (Node *)malloc(sizeof(Node));list->next = NULL;list->prev = NULL;
}

查找(不用再判斷一下空不空)

Node * find(int key,Node * list)
{Node * head = list->next;//從頭節點后面開始找while(head != NULL && head->key != key)//找到或空跳出head = head->next;return head;
}

打印

void printList(Node * list)//打印
{Node * temp = list->next;頭節點下一個開始while(temp != NULL){printf("%d ",temp->key);temp = temp->next;}printf("\n");
}

刪除指定結點

void delete(Node * list)//刪除指定結點
{list->prev->next = list->next;前面后面指針改了,再free自己即可list->next->prev = list->prev;free(list);
}

配合一下刪除:

void deleteKey(int key,Node * list)
{delete(find(key,list));
}

頭插:

void insertHead(int key,Node * list)//頭插
{Node * newNode = (Node *)malloc(sizeof(Node));//初始化newNode->key = key;newNode->next = list->next;//賦值后繼if(list->next != NULL)//如果有后繼,賦值后繼的前指針為新結點list->next->prev = newNode;list->next = newNode;//改頭newNode->prev = list;//賦值新結點前指針
}

按下標插入

單鏈表都寫了,我就不寫長度函數和判斷非法了,用的時候注意吧。

void insert(int key,Node * list,int index)
{Node * head=list;//最后指到要插位置的前一個即可Node * newNode = (Node *)malloc(sizeof(Node));//初始化newNode->key = key;while(index--)head = head->next;newNode->next = head->next;//修改指針newNode->prev = head;head->next = newNode;
}

指定某值后插入不寫了,和這個修改指針邏輯一樣,再傳一個find配合一下就行了。

?

然后簡單測試

int main()
{Node * list = NULL;init(list);insertHead(1,list);insertHead(2,list);insertHead(3,list);printList(list);deleteKey(2,list);printList(list);insert(10,list,0);printList(list);
}

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/445605.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/445605.shtml
英文地址,請注明出處:http://en.pswp.cn/news/445605.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數據結構作業1 講解和拓展

原題來自雪梨教育 http://www.edu2act.net/task/list/checked/ 題后給出講解和擴展 任務1_1 比較下列算法的時間復雜度 任務描述&#xff1a; 下面給出4個算法&#xff0c;請分析下列各算法的時間復雜度&#xff0c;請寫清楚題號&#xff0c;并將每個小題的分析過程寫出來&…

KMP+DP1

Description 求一個字符串的所有前綴在串中出現的次數之和 Input 多組用例&#xff0c;每組用例占一行為一個長度不超過100000的字符串&#xff0c;以文件尾結束輸入 Output 對于每組用例&#xff0c;輸出該字符串的所有前綴在串中出現的次數之和&#xff0c;結果模256 Samp…

數據結構課上筆記5

介紹了鏈表和基本操作 用一組物理位置任意的存儲單元來存放線性表的數據元素。 這組存儲單元既可以是連續的&#xff0c;也可以是不連續的&#xff0c;甚至是零散分布在內存中的任意位置上的。因此&#xff0c;鏈表中元素的邏輯次序和 物理次序不一定相同。 定義&#xff1a; …

并查集入門三連:HDU1213 POJ1611 POJ2236

HDU1213 http://acm.hdu.edu.cn/showproblem.php?pid1213 問題描述 今天是伊格納修斯的生日。他邀請了很多朋友。現在是晚餐時間。伊格納修斯想知道他至少需要多少桌子。你必須注意到并非所有的朋友都互相認識&#xff0c;而且所有的朋友都不想和陌生人呆在一起。 這個問題…

Java設計模式(2 / 23):觀察者模式

定義 觀察者&#xff08;Observer&#xff09;模式定義了對象之間的一對多依賴&#xff0c;這樣一來&#xff0c;當一個對象改變狀態時&#xff0c;它的所有依賴者都會收到通知并自動更新。 OO設計原則&#xff1a;為了交互對象之間的松耦合設計而努力。 案例&#xff1a;氣…

二叉樹概述

各種實現和應用以后放鏈接 一、二叉樹的基本概念 二叉樹&#xff1a;二叉樹是每個節點最多有兩個子樹的樹結構。 根節點&#xff1a;一棵樹最上面的節點稱為根節點。 父節點、子節點&#xff1a;如果一個節點下面連接多個節點&#xff0c;那么該節點稱為父節點&#xff0c;它…

Java設計模式(1 / 23):策略模式

定義 策略&#xff08;Strategy&#xff09;模式定義了算法族&#xff0c;分別封裝起來&#xff0c;讓它們之間可以互相替換 &#xff0c;此模式讓算法的變化獨立于使用算法的客戶。 案例&#xff1a;模擬鴨子應用 一開始 新需求&#xff1a;模擬程序需要會飛的鴨子 在父類新…

Java設計模式(3 / 23):裝飾者模式

文章目錄定義案例1&#xff1a;三點幾啦首次嘗試再次嘗試設計原則&#xff1a;類應該對擴展開放&#xff0c;對修改關閉嘗用裝飾者模式裝飾者模式特征本例的類圖放碼過來飲料類HouseBlendDarkRoastEspressoDecaf調料裝飾類MilkMochaSoyWhip運行測試類案例2&#xff1a;編寫自己…

c語言知識體系

原文&#xff1a;https://blog.csdn.net/lf_2016/article/details/80126296#comments

《游戲編程入門 4th》筆記(1 / 14):Windows初步

文章目錄Windows編程概述獲取Windows理解Windows消息機制多任務多線程事件處理DirectX快速概覽Direct3D是什么Window程序基礎創建第一個Win32項目理解WinMainWinMain函數調用完整的WinMainGetMessage函數調用尋求幫助Windows編程概述 DirectX&#xff0c;流行的游戲編程庫。它…

17校招真題題集(1)1-5

注&#xff1a;本系列題目全是按照通過率降序來排列的&#xff0c;基本保證題目難度遞增。 1、 題目名稱&#xff1a;游戲任務標記 來源&#xff1a;騰訊 題目描述 游戲里面有很多各式各樣的任務&#xff0c;其中有一種任務玩家只能做一次&#xff0c;這類任務一共有1024個…

《游戲編程入門 4th》筆記(2 / 14):監聽Windows消息

文章目錄編寫一個Windows程序理解InitInstanceInitInstance函數調用InitInstance的結構理解MyRegisterClassMyRegisterClass函數調用MyRegisterClass的作用揭露WinProc的秘密WinProc函數調用WinProc的大秘密什么是游戲循環The Old WinMain對持續性的需要實時終止器WinMain和循環…

17校招真題題集(2)6-10

注&#xff1a;本系列題目全是按照通過率降序來排列的&#xff0c;基本保證題目難度遞增。 6、 題目名稱&#xff1a;Fibonacci數列 來源&#xff1a;網易 題目描述 Fibonacci數列是這樣定義的&#xff1a; F[0] 0 F[1] 1 for each i ≥ 2: F[i] F[i-1] F[i-2] 因此&am…

QT5的數據庫

#include <QtSql> QT sql QSqlDatabase類實現了數據庫連接的操作 QSqlQuery類執行SQL語句 QSqlRecord類封裝數據庫所有記錄 QSqlDatabase類 [cpp] view plaincopy print?QSqlDatabase db QSqlDatabase::addDatabase("QOCI"); db.setHostName("localh…

數據結構課上筆記6

本節課介紹了單鏈表的操作實現細節&#xff0c;介紹了靜態鏈表。 鏈表帶頭的作用&#xff1a;對鏈表進行操作時&#xff0c;可以對空表、非空表的情況以及 對首元結點進行統一處理&#xff0c;編程更方便。 下面給出帶頭的單鏈表實現思路&#xff1a; 按下標查找&#xff1a; …

《Unity2018入門與實戰》筆記(9 / 9):個人總結

個人總結 腳本語言學習的竅門 盡可能多讀、多寫、多說腳本語言&#xff01; Link 游戲制作步驟 設計游戲時一般會遵循5個步驟&#xff1a; 羅列出畫面上所有的對象。確定游戲對象運行需要哪些控制器腳本。確定自動生成游戲對象需要哪些生成器腳本。準備好用于更新UI的調度…

17校招真題題集(3)11-15

注&#xff1a;本系列題目全是按照通過率降序來排列的&#xff0c;基本保證題目難度遞增。 11、 題目名稱&#xff1a;買蘋果 來源&#xff1a;網易 題目描述 小易去附近的商店買蘋果&#xff0c;奸詐的商販使用了捆綁交易&#xff0c;只提供6個每袋和8個每袋的包裝(包裝不…

Qt學習:QDomDocument

QDomDocument類代表了一個XML文件 QDomDocument類代表整個的XML文件。概念上講&#xff1a;它是文檔樹的根節點&#xff0c;并提供了文檔數據的基本訪問方法。由于元素、文本節點、注釋、指令執行等等不可能脫離一個文檔的上下文&#xff0c;所以文檔類也包含了需要用來創建這些…

《事實:用數據思考,避免情緒化決策》筆記

文章目錄一分為二負面思維直線思維恐懼本能規模錯覺以偏概全命中注定單一視角歸咎他人情急生亂一分為二 要做到實事求是&#xff0c; 就要做到當你聽到一分為二的說法時&#xff0c; 你就能迅速認識到這種說法描述的是一種兩極分化的圖畫&#xff0c; 而兩極之間存在一道巨大的…

順序存儲線性表實現

在計算機中用一組地址連續的存儲單元依次存儲線性表的各個數據元素,稱作線性表的順序存儲結構。 順序存儲結構的主要優點是節省存儲空間&#xff0c;因為分配給數據的存儲單元全用存放結點的數據&#xff08;不考慮c/c語言中數組需指定大小的情況&#xff09;&#xff0c;結點之…