鱼C论坛

 找回密码
 立即注册
查看: 1195|回复: 6

[已解决]使用typedef的一些问题

[复制链接]
发表于 2020-11-1 11:15:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Justin1 于 2020-11-1 11:16 编辑

我这段程序到底是什么问题呢?
网上搜索了下也有点云里雾里。
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. typedef struct {
  4.     int data;
  5.     ListNode* next;
  6. }ListNode;

  7. void printNode(ListNode* l1);

  8. void printNode(ListNode* l1) {
  9.     while (l1 != NULL) {
  10.         printf("%d\n", l1->data);
  11.         l1 = l1->next;
  12.     }
  13. }

  14. int main() {
  15.     ListNode* l1 = (ListNode*)malloc(sizeof(ListNode*));
  16.     l1->data = 0;
  17.     l1->next = NULL;
  18.     ListNode* p = l1;
  19.     ListNode* q;
  20.     int i = 1;
  21.     for (i; i <= 10; i++) {
  22.         q = (ListNode*)malloc(sizeof(ListNode*));
  23.         q->data = i;
  24.         p->next = q;
  25.         p = p->next;
  26.     }
  27.     printNode(l1);
  28.     return 0;
  29. }
复制代码

Screenshot 2020-11-01 111601.png
最佳答案
2020-11-1 15:32:01
第6行
  1. ListNode* next;
复制代码

此时ListNode都还没有被typedef过,编译器不知道ListNode是什么
建议这样:
  1. typedef struct ListNode
  2. {
  3. ...
  4. }ListNode;
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-1 12:17:17 | 显示全部楼层
本帖最后由 jackz007 于 2020-11-1 12:42 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. typedef struct Node {
  4.     int data                                                ;
  5.     struct Node * next                                      ;
  6. } ListNode                                                  ;

  7. void printNode(ListNode * l1)
  8. {
  9.         while(l1) {
  10.                 printf("%d\n" , l1 -> data)                 ;
  11.                 l1 = l1 -> next                             ;
  12.         }
  13. }

  14. int main()
  15. {
  16.         ListNode * l1 , * p , * q                            ;
  17.         for (int i = 0 ; i <= 10 ; i ++) {
  18.                 q = (ListNode *)malloc(sizeof(ListNode))     ;
  19.                 q -> data = i                                ;
  20.                 q -> next = NULL                             ;
  21.                 if(i) p -> next = q                          ;
  22.                 else l1 = q                                  ;
  23.                 p = q                                        ;
  24.         }        
  25.         printNode(l1)                                        ;
  26. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-1 12:47:09 | 显示全部楼层
  1. #include<stdio.h>
  2. #include<stdlib.h>



  3. typedef struct ListNode{
  4.     int data;
  5.     struct ListNode* next;
  6. }ListNode;



  7. void printNode(ListNode* l1) {
  8.     while (l1 != NULL) {
  9.         printf("%d\n", l1->data);
  10.         l1 = l1->next;
  11.     }
  12. }



  13. int main() {
  14.     ListNode* l1 = (ListNode*)malloc(sizeof(ListNode));
  15.     l1->data = 0;
  16.     l1->next = NULL;
  17.     ListNode* p = l1, * q;


  18.     for (int i = 1; i <= 10; i++) {
  19.         q = (ListNode*)malloc(sizeof(ListNode));
  20.         q->data = i;
  21.         p->next = q;
  22.         p = p->next;
  23.     }

  24.     p->next = NULL;
  25.     printNode(l1);
  26.     return 0;
  27. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-1 12:59:12 | 显示全部楼层

为什么要分号对齐……?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-1 13:11:42 | 显示全部楼层
永恒的蓝色梦想 发表于 2020-11-1 12:59
为什么要分号对齐……?

      不为别的,只是为了整齐好看!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-1 15:15:01 | 显示全部楼层
jackz007 发表于 2020-11-1 13:11
不为别的,只是为了整齐好看!

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-1 15:32:01 | 显示全部楼层    本楼为最佳答案   
第6行
  1. ListNode* next;
复制代码

此时ListNode都还没有被typedef过,编译器不知道ListNode是什么
建议这样:
  1. typedef struct ListNode
  2. {
  3. ...
  4. }ListNode;
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-12 09:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表