雨与鱼余玉 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 对于这个问题的算法代码
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow
  • ¥20 有人知道这种图怎么画吗?
  • ¥15 pyqt6如何引用qrc文件加载里面的的资源
  • ¥15 安卓JNI项目使用lua上的问题
  • ¥20 RL+GNN解决人员排班问题时梯度消失
  • ¥60 要数控稳压电源测试数据