用尾插法创建链表

题目描述

输入一系列字符以#作为结束标志,用尾插法创建链表并存储数据,并输出链表数据.如果输入的只有结束符,则输出empty list

输入

第一行输入一个字符串,以#结束

例如输入:

abcde#

输出

链表所有数据,数据之间用空格分开

a b c d e 

#include"stdio.h"
#include"stdlib.h"

typedef struct node{
    char data;
    struct node *next; 
}Node;

// 创建链表函数
void creatList(Node * head);
// 输出链表函数
void output(Node *h);

int main()
{
    
    Node *head =(Node*)malloc(sizeof(Node));
    head->next= NULL;

    // 尾插法创建链表
    creatList( head);

    // 输出链表
    output(head);

    return 0;
}

// 创建链表函数,通过尾插法
void creatList(Node * head)
{
    Node *tail =head;  // 定义尾指针初始指向头节点
    char c;
    while(scanf("%c",&c)&&c!='#')  // 循环读取字符直到输入'#'
    {
        Node *newNode =(Node*)malloc(sizeof(Node));  // 创建新节点
        newNode->data= c;  // 设置新节点数据为读取的字符
        newNode->next= NULL;
        tail->next= newNode;  // 将新节点添加到尾指针后
        tail = newNode;  // 更新尾指针为新节点
    }
}

// 输出链表函数
void output(Node *h)
{
    Node *p = h->next;  // 从头节点的下一个节点开始
    if(p==NULL)  // 如果链表为空
    {
        printf("empty list");
    }else{
        while(p)  // 遍历链表
        {
            printf("%c ",p->data);  // 输出节点数据
            p= p->next;  // 移动到下一个节点
        }
        printf("\n");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值