辣条星星 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日

悬赏问题

  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow
  • ¥20 有人知道这种图怎么画吗?
  • ¥15 pyqt6如何引用qrc文件加载里面的的资源
  • ¥15 安卓JNI项目使用lua上的问题
  • ¥20 RL+GNN解决人员排班问题时梯度消失