#include <stdio.h>#include <stdlib.h>#include <time.h>typedef struct Node{int data;struct Node *next;}Node, *pt_Node;//初始化生成頭結(jié)點(diǎn)static int InitList(pt_Node L)//為什么是*L才正確???就這里也不懂{L = (pt_Node)malloc(sizeof(Node));if (!L){return -1;}L->next = NULL;return 0;}/*統(tǒng)計(jì)鏈表的長度*/static int ListLenth(pt_Node L){int i = 0;pt_Node p = L->next;while (p){i++;p = p->next;}return i;}int main(void){int lenth;pt_Node link;//不能是*link?為什么InitList(link);lenth = ListLenth(link);printf("the lenth is %d", lenth);return 0;}
1 回答

手掌心
TA貢獻(xiàn)1942條經(jīng)驗(yàn) 獲得超3個贊
這個代碼的流程 ,是在主函數(shù)中定義一個頭節(jié)點(diǎn)link
然后通過函數(shù)InitList來給頭節(jié)點(diǎn)賦值。
既然要給link賦值,就需要參數(shù)是link的指針類型,否則無法傳回主函數(shù)。
于是需要定義成
static int InitList(pt_Node *L)
同時在函數(shù)中給*L賦值。
調(diào)用的時候 用InitList(&link);
- 1 回答
- 0 關(guān)注
- 93 瀏覽
添加回答
舉報
0/150
提交
取消