辣条星星 2022-04-17 20:25 采纳率: 100%
浏览 23
已结题

为什么单链表没有逆转成功啊

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

typedef int ElemType;
typedef struct LNode
{
ElemType data;
LNode *next;
}LNode,*LinkList;

void CreateList(LinkList &L,int n)
{
LNode *r,*p;
L = new LNode;
L->next = NULL;
r = L;
for(int i=0;i<n;i++)
{
p = new LNode;
scanf("%d",&p->data);
p->next = NULL;
r->next = p;
r = p;
}
}

void CreateList_1(LinkList &L){
LinkList t;
ElemType data;
printf("");
while (1){
if (scanf("%d",&data) == 1){
t = new LNode;
t->data = data;
t->next = L->next;
L->next = t;
}
if ((getchar()) == '\n') break;
}
}

void Inverse(LinkList &L)
{
LinkList p,q;
p = L->next;
L->next = NULL;
while(p != NULL)
{
q = p->next;
p->next = L->next;
L->next = p;
p = q;
}
}

int main()
{
int n;
LinkList L,L1;
CreateList(L1,n);
printf("逆转后的单链表为:\n" );
Inverse(L);
CreateList_1(L);
return 0;
}

img

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2022-04-18 15:21
    关注

    修改处见注释,供参考:

    #include<stdio.h>
    #include<stdlib.h>
    
    typedef int ElemType;
    typedef struct LNode
    {
        ElemType data;
        LNode*   next;
    }LNode, * LinkList;
    
    void CreateList(LinkList& L, int n)
    {
        LNode* r, * p;
        L = new LNode;
        L->next = NULL;
        r = L;
        for (int i = 0; i < n; i++)
        {
            p = new LNode;
            scanf("%d", &p->data);
            p->next = NULL;
            r->next = p;
            r = p;
        }
    }
    
    void CreateList_1(LinkList& L) {
        LinkList t;
        ElemType data;
        printf("");
        while (1) {
            if (scanf("%d", &data) == 1) {
                t = new LNode;
                t->data = data;
                t->next = L->next;
                L->next = t;
            }
            if ((getchar()) == '\n') break;
        }
    }
    
    void Inverse(LinkList& L)
    {
        LinkList p, q;
        p = L->next;
        L->next = NULL;
        while (p != NULL)
        {
            q = p;           //q = p->next;
            p = p->next;    //修改
            q->next = L->next; //p->next = L->next;
            L->next = q;  //L->next = p;
                          //p = q;
        }
    }
    void showList(LinkList L)  //修改
    {
        LinkList p = L;
        while (p->next) {
            printf("%d ", p->next->data);
            p = p->next;
        }
        printf("\n");
    }
    
    int main()
    {
        int n;
        LinkList L, L1;
        printf("请输入链表的长度:"); //修改
        scanf("%d", &n);             //修改
        CreateList(L1, n);
        showList(L1);               //修改
    
        printf("逆转后的单链表为:\n");
        Inverse(L1);     //Inverse(L); 修改
        showList(L1);    //修改
    
        //CreateList_1(L);  修改
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 Android STD快速启动
  • ¥15 如何使用simulink建立一个永磁同步直线电机模型?
  • ¥30 天体光谱图的的绘制并得到星表
  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动