30-数据结构-创建链表(2)


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

//---【1】创建结点数据类型

typedef struct node
{

    int data;
    struct node* pnext;

} NODE, * PNODE;


PNODE creat_list(void);
void travel_list(PNODE phead);

int main(void)
{
    //---------------------------------------【2】写框架----------------


    PNODE phead = NULL;
    //----【3】创建链表---
    phead = creat_list();  //要在这个函数里创建链表,在下一个函数里使用,就要用动态分配内存
    //--- 【4】遍历链表--
    travel_list(phead);

    return 0;
}
PNODE    creat_list(void)
{
    //【3.1】创建头指针
    PNODE phead = (PNODE)malloc(sizeof(PNODE));
    //【3.2】创建新指针
    //PNODE pnew = (PNODE)malloc(sizeof(PNODE));
    //【3.3】创建尾指针
    PNODE ptail;// = (PNODE)malloc(sizeof(PNODE))
    ptail = phead;
    ptail->pnext = NULL;
    //【3.4】定义链表长度和链表的内容
    int len, val;


    //【3.5】提示用户输入长度
    printf("请输入链表的长度");
    scanf("%d", &len);
    //【3.6】输入每一个节点的内容
    for (int i=0;i<len;++i)
    {
        printf("请输入第%d个结点的值",i+1);
        scanf("%d", &val);
        
        //【3.7】把输入内容给到节点
        PNODE pnew = (PNODE)malloc(sizeof(NODE));//这个函数不能写在for循环外面,因为这是一个新的节点
        pnew->data = val;
        //【3.8】尾指针指向新的节点
        ptail->pnext = pnew;//挂,把新生成的节点挂到ptail
        //【3.9】新指针
        pnew->pnext = NULL;//新节点成为左后一个,所以清空
        //【3.10】 尾结点重新指向最后 
        ptail = pnew;
        
    }


    


    return phead;
}

void travel_list(PNODE phead)
{

    PNODE p = phead->pnext;
    while (NULL != p)
    {
        printf("%d",p->data);
        p = p->pnext;
    }
    printf("\n");
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值