辣条星星 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 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图