all righyyyy 2023-02-16 13:21 采纳率: 97.4%
浏览 44
已结题

关于#c语言#的问题:单链表逆序输出




#include <stdio.h>
#include <string.h>

struct node
{
    char value;
    struct node* link;
};

int main()
{
    struct node* top, * p;
    char c;
    top = NULL;
    while ((c = getchar) != '\n');
    {
        p = (struct node*)malloc(sizeof(struct node));
        p->value = c;
        p->link = top;
        top = p;
    }
    while (top)
    {
        p = top;
        top = top->link;
        putchar(p->value);
    }
}

请问top = top->link 是指向空指针吗?

  • 写回答

5条回答 默认 最新

  • qzjhjxj 2023-02-16 15:46
    关注

    这段代码是头插法生成链表,当输入第一个字符 a 时,因起始 top = NULL; 所以 p->link = top; 就是等价于 p->link = NULL; ,然后接下来就将top = p;,此时top就不再是NULL了,它指向(记录)了第一个结点 p 的地址。循环执行 while ((c = getchar()) != '\n') 这句,读入第二个字符 b, 此时的 top 就是第一个结点的地址,它衔接在新申请的结点 p 的尾部即 p->link = top;,然后把 top = p; 将 top 指向新生成的第二个结点头,如此类推,就实现了输入顺序 abc,插入链表:a ,b->a ,c->b->a,后输入的字符 插在 前一个输入的字符 之前。代码有点小问题,修改如下,供参考:

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    struct node
    {
        char   value;
        struct node* link;
    };
    int main()
    {
        struct node* top, * p;
        char c;
        top = NULL;
        while ((c = getchar()) != '\n')   //(c = getchar) != '\n' // ;
        {
            p = (struct node*)malloc(sizeof(struct node));
            p->value = c;
            p->link = top;
            top = p;
        }
        
        while (top)
        {
            p = top;
            top = top->link;
            putchar(p->value);
        }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 2月24日
  • 已采纳回答 2月16日
  • 创建了问题 2月16日

悬赏问题

  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启