雨与鱼余玉 2022-04-08 22:27 采纳率: 80%
浏览 35
已结题

顺序单链表的倒置 大一小白请教

问题遇到的现象和发生背景

在对单链表进行倒置时 无法输出倒置的内容

问题相关代码,请勿粘贴截图
void  reverseL(LinkNode *&L)
 {
// 在带头结点的单链线性表L进行反转
    /********** Begin **********/
   LinkNode*p1,*p2,*s;
   p1=L;
   p2=L->next;
   p1->next=NULL;

   while(p2->next!=NULL)
   {
      s=p2->next;
      p2->next=p1;
      p1=p2;
      p2=s;


   }


运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果
  • 写回答

2条回答 默认 最新

  • Frank_Liuxing 2022-04-09 09:20
    关注

    你的算法看起来是对的。
    不能输出的原因是:你没有把p1赋值给L,导致反转后L就是最后一个节点。最后加一个 L = p1就行了。
    但是while(p2->next !=NULL)这个地方有个缺陷,链表只有一个节点时,p2初始值就为空,会导致程序挂掉。下面是我写的测试代码,试过没问题。

    
    #include <stdio.h>
    
    struct LinkNode
    {
        int value;
        LinkNode* next;
    };
    void reverse(LinkNode*& L)
    {
        //p1指向反转后的链表头
        //p2指向还未进行反转的链表头
        //反转的算法就是:从p2的头上取一个节点,放到p1的前面,直到p2的尾部
        LinkNode* p1, * p2;
    
        p1 = L;
        p2 = L->next;
        p1->next = nullptr;
    
        while (p2)
        {
            LinkNode* temp = p2;
            p2 = p2->next;
            temp->next = p1;
            p1 = temp;
        }
    
        L = p1;
    }
    
    
    
    int main()
    {
       //构建一个链表
        LinkNode node1,node2,node3;
        node1.next = &node2;
        node2.next = &node3;
        node3.next = nullptr;
        node1.value = 1;
        node2.value = 2;
        node3.value = 3;
    
        LinkNode* head = &node1;
    
        printf("before reverse:");
        for (LinkNode* p = head; p != nullptr; p = p->next)
        {
            printf("%d ", p->value);
        }
        printf("\n");
        
        reverse(head);
        printf("after reverse:");
        for (LinkNode* p = head; p != nullptr; p = p->next)
        {
            printf("%d ", p->value);
        }
        printf("\n");
        
       return 0;
    }
    
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月17日
  • 已采纳回答 4月9日
  • 创建了问题 4月8日

悬赏问题

  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多
  • ¥50 求一个win系统下运行的可自动抓取arm64架构deb安装包和其依赖包的软件。
  • ¥60 fail to initialize keyboard hotkeys through kernel.0000000000
  • ¥30 ppOCRLabel导出识别结果失败
  • ¥15 Centos7 / PETGEM
  • ¥15 csmar数据进行spss描述性统计分析
  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题