[爆卦]typedef struct指標是什麼?優點缺點精華區懶人包

為什麼這篇typedef struct指標鄉民發文收入到精華區:因為在typedef struct指標這個討論話題中,有許多相關的文章在討論,這篇最有參考價值!作者sbk8027 (小朱)看板C_and_CPP標題[問題] Linked list 想法是否正確...


各位前輩大家好 小弟最近自學C語言到資料結構的部分

今天在練習單向的單向鏈結

我用的是 Dev C++來寫 電腦是win7

因為剛進入這個章節所以只是先簡單的 創造節點 連結節點 刪除節點

我預期的動作流程如 http://imgur.com/qYbrYgG

程式碼如下

#include<stdio.h>
#include <stdlib.h>

struct listNode {
char data;
struct listNode *nextPtr;
};

typedef struct listNode *ListNodePtr;

int main(void){
ListNodePtr startptr=NULL;//把startptr指向NULL

ListNodePtr ONE_node;//創立第一個節點
ONE_node=(ListNodePtr)malloc(sizeof(listNode));//給定實體空間
startptr=ONE_node;//把startptr指向第一個節點

ONE_node->data=10;
ONE_node->nextPtr=NULL;//把第一個節點指向NULL

ListNodePtr TWO_node;//創立第二個節點希望把第一個節點指向第二個節點
TWO_node=(ListNodePtr)malloc(sizeof(listNode));//給定實體空間

TWO_node->data=11;
TWO_node->nextPtr=NULL;//把第二個節點指向NULL
ONE_node->nextPtr=TWO_node;//把第一個節點指向第二個節點

ListNodePtr THREE_node;//創立第三個節點希望第二個節點指向第三個節點
THREE_node=(ListNodePtr)malloc(sizeof(listNode));//給定實體空間
THREE_node->data=13;
THREE_node->nextPtr=NULL;//把第三個節點指向NULL
TWO_node->nextPtr=THREE_node;//把第二個節點指向地三個節點

ListNodePtr FOUR_node;//創立第四個節點
//希望插在第二個節點和第三個節點中間
FOUR_node=(ListNodePtr)malloc(sizeof(listNode));//給定實體空間
FOUR_node->data=12;
TWO_node->nextPtr=FOUR_node;//把第二個節點指向第四個節點
FOUR_node->nextPtr=THREE_node;//把第四個節點只向第三個節點

printf("\n%s",THREE_node->nextPtr);
printf("\n%d",THREE_node);
printf("\n%d",FOUR_node->nextPtr);

/////////////////////////////////////////////////////
//刪除節點
//我希望能刪除第一個節點
startptr=TWO_node;//先把起始位置改成第二個節點
free(ONE_node);//釋放第一個節點

printf("\n%d",ONE_node->data);
//這裡輸出的值是-112不知道是否正確
////////////////////////////////////////////////////
//希望能刪除第四個節點
//把第二個節點指向第三個節點
TWO_node->nextPtr=THREE_node;
free(FOUR_node);//釋放第四個節點

printf("\n%d",TWO_node->nextPtr);
printf("\n%d",THREE_node);
printf("\n%d",FOUR_node->nextPtr);

}


因為自己練習的所以不太知道這樣做是否正確,想請前輩們幫小弟看一下

感覺這個章節有點困難似懂非懂的,而且這個做法好像有點蠢

再麻煩各位前輩了

萬分感謝!!感激不盡!!!!

--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.169.89.201
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1460385882.A.255.html
※ 編輯: sbk8027 (1.169.89.201), 04/11/2016 22:53:00
wtchen: typedef struct listNode *ListNodePtr; -> 這行是怎樣? 04/11 22:59
wtchen: typedef應該沒有把struct定義成pointer的能力吧 04/11 23:00
LPH66: 樓上漏看 * 了 04/11 23:01
WBTs: http://goo.gl/75ehH3 04/11 23:02
WBTs: typedef 可不用,重點在宣告指向結構的指標 04/11 23:15
WBTs: 你的printf是要prinf節點的值? 04/11 23:25
Frozenmouse: 別 free 掉後又再去取值,移到 free 前 @@ 04/11 23:43
Frozenmouse: 其他感覺還好,會覺得有點蠢會不會是因為你額外又用 04/11 23:47
Frozenmouse: 了四個指標去指個別的node?XD 04/11 23:47
WBTs: https://ideone.com/3upCpN 我照你的要求寫的,參考1下 04/11 23:53
wtchen: typedef A B 是把type A取個別名叫B 04/11 23:56
wtchen: 可我沒看過typedef A B*的用法,是我太孤陋寡聞? 04/11 23:56
wtchen: 少掉typedef我就能理解了.... 04/11 23:58
WBTs: typedef A B* 好像函數指標 04/12 00:02
Frozenmouse: typedef A* B 04/12 00:05
Frozenmouse: 如果是 typedef A B* 應該會錯吧… 04/12 00:07
WBTs: 串列應該最少2個START和NEW,只是要像我第1個連結一樣從頭找 04/12 00:07
WBTs: 另外若不要看起來那麼多就寫在函數,傳要加入or刪除的節點 04/12 00:13
LPH66: typedef 的解釋法最簡單的正是把 typedef 去掉 04/12 00:14
LPH66: 去掉之後若變成宣告某名為某型態的變數 04/12 00:14
LPH66: 這 typedef 即是定此名為此型態的別名 04/12 00:15
wtchen: 所以typedef struct listNode *ListNodePtr; 04/12 00:23
wtchen: 這裡的*ListNodePtr會是指標還是整個struct? 04/12 00:23
Frozenmouse: A=struct listNode *, B=ListNodePtr 04/12 00:26
Frozenmouse: 如果你堅持要說*B的話那它是那個結構無誤XD 04/12 00:26
WBTs: 指標吧 04/12 00:27
wtchen: 看來我腦殘了,這樣我了了 XD 04/12 00:32
sbk8027: 感謝各位大大指點迷津!! 04/12 23:12

你可能也想看看

搜尋相關網站