鱼C论坛

 找回密码
 立即注册
查看: 2131|回复: 4

[已解决]c语言链表

[复制链接]
发表于 2019-3-5 20:28:37 | 显示全部楼层 |阅读模式

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

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

x
struct NodeT {
        int data;
        struct NodeT *next;
};

typedef struct NodeT node;



node *createNode(int v){
        node *new;
        new = (node *)malloc(sizeof(node));
        assert(new != NULL);
        new->data = v;
        new->next = NULL;
        return new;
}
大佬,下面的那个createNode,这是什么用法,我的意思是这也不是定义的函数,返回的还是一个结构体,不太懂
最佳答案
2019-3-5 20:46:07
本帖最后由 jackz007 于 2019-3-5 20:53 编辑

    楼主猜对了,node * createNode(int v) 还真是函数定义,请看以下示例:
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <assert.h>

  5. typedef struct NodeT {
  6.         int data            ;
  7.         struct NodeT * next ;
  8. } node                      ;

  9. node * createNode(int v)
  10. {
  11.         node * n                          ; // 变量名不可以用 new 否则无法编译
  12.         n = (node *) malloc(sizeof(node)) ; // 为链表新节点分配内存空间
  13.         assert(n != NULL)                 ; // 确保内存分配成功
  14.         n -> data = v                     ; // 为新节点赋值
  15.         n -> next = NULL                  ; // 新节点链表指针指向 NULL
  16.         return n                          ; // 返回指向新链表节点的指针
  17. }

  18. main(void)
  19. {
  20.     node * p                   ;
  21.     p = createNode(200)        ; // 创建一个data 成员值为 200 的新节点
  22.     printf("%d\n" , p -> data) ;
  23. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-3-5 20:46:07 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2019-3-5 20:53 编辑

    楼主猜对了,node * createNode(int v) 还真是函数定义,请看以下示例:
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <assert.h>

  5. typedef struct NodeT {
  6.         int data            ;
  7.         struct NodeT * next ;
  8. } node                      ;

  9. node * createNode(int v)
  10. {
  11.         node * n                          ; // 变量名不可以用 new 否则无法编译
  12.         n = (node *) malloc(sizeof(node)) ; // 为链表新节点分配内存空间
  13.         assert(n != NULL)                 ; // 确保内存分配成功
  14.         n -> data = v                     ; // 为新节点赋值
  15.         n -> next = NULL                  ; // 新节点链表指针指向 NULL
  16.         return n                          ; // 返回指向新链表节点的指针
  17. }

  18. main(void)
  19. {
  20.     node * p                   ;
  21.     p = createNode(200)        ; // 创建一个data 成员值为 200 的新节点
  22.     printf("%d\n" , p -> data) ;
  23. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2019-3-6 09:01:51 | 显示全部楼层
就是函数,只不过返回的是一个结构体的指针
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-3-6 10:33:25 | 显示全部楼层
jackz007 发表于 2019-3-5 20:46
楼主猜对了,node * createNode(int v) 还真是函数定义,请看以下示例:

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

使用道具 举报

 楼主| 发表于 2019-3-6 10:34:02 | 显示全部楼层
BngThea 发表于 2019-3-6 09:01
就是函数,只不过返回的是一个结构体的指针

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-14 01:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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