#include <stdio.h>#include <stdlib.h>#include <time.h>typedef struct Node{int data;struct Node *next;}Node, *pt_Node;//初始化生成頭結點static int InitList(pt_Node L)//為什么是*L才正確???就這里也不懂{L = (pt_Node)malloc(sizeof(Node));if (!L){return -1;}L->next = NULL;return 0;}/*統計鏈表的長度*/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貢獻1942條經驗 獲得超3個贊
這個代碼的流程 ,是在主函數中定義一個頭節點link
然后通過函數InitList來給頭節點賦值。
既然要給link賦值,就需要參數是link的指針類型,否則無法傳回主函數。
于是需要定義成
static int InitList(pt_Node *L)
同時在函數中給*L賦值。
調用的時候 用InitList(&link);
- 1 回答
- 0 關注
- 86 瀏覽
添加回答
舉報
0/150
提交
取消