「已注销」 2023-03-28 23:56 采纳率: 71.4%
浏览 109
已结题

在有序单链表中插入x使插入后的链表保存有序并输出

【问题描述】设单链表Va中的数据元素递增有序。试编写程序,将数据X插入单链表Va,要求插入后保持该表的有序性。

【输入形式】
【输出形式】
【样例输入】

              8 

              25 28  36  78  96  102  980  1000

               88

【样例输出】25 28 36 78 88 96 102 980 1000
【样例说明】单链表Va表长为8

                  Va:25 28  36  78  96  102  980  1000

                 插入后:25 28 36 78 88 96 102 980  1000

我的代码如下

#include<iostream>
#include<malloc.h>
using namespace std;
typedef struct LNode
{
    int data;
    struct LNode *next;
}LNode,*linklist;
void Initlist(linklist &L)
{
    L=(linklist)malloc(sizeof(linklist));
    L->next=NULL;
}
void creatlist(linklist L,int n)
{
    linklist r;
    r=L;
    for(int i=0;i<n;i++)
    {
        linklist p;
        p=(linklist)malloc(sizeof(linklist));
        cin>>p->data;
        p->next=NULL;
        r->next=p;
        r=p;
    }
}
void Insertlist(linklist &L,int x)
{
    linklist p;
    p=L;
    linklist q;
    q=(linklist)malloc(sizeof(linklist));
    while(p->next->data<x)
    {
        p=p->next;
    }
    q->data=x;
    q->next=p->next;
    p->next=q;
}
void print(linklist L)
{
    linklist p;
    p=L->next;
    while(p!=NULL)
    {
        cout<<p->data<<" ";
        p=p->next;
    }
}
int main()
{
    linklist L;
    int n,x;
    cin>>n;
    Initlist(L);
    creatlist(L,n);
    cin>>x;
    Insertlist(L,x);
    print(L);
    return 0;
}

遇到的问题

img

img


该怎么改正这个代码才能使测试数据输出正确?不知道问题出在哪

  • 写回答

3条回答 默认 最新

  • qzjhjxj 2023-03-29 11:55
    关注

    修改如下,供参考:

    #include<iostream>
    #include<malloc.h>
    using namespace std;
    typedef struct LNode
    {
        int data;
        struct LNode* next;
    }LNode, * linklist;
    void Initlist(linklist& L)
    {
        L = (linklist)malloc(sizeof(linklist));
        L->next = NULL;
    }
    void creatlist(linklist L, int n)
    {
        linklist r;
        r = L;
        for (int i = 0; i < n; i++)
        {
            linklist p;
            p = (linklist)malloc(sizeof(LNode));
            //p = (linklist)malloc(sizeof(linklist));
            cin >> p->data;
            p->next = NULL;
            r->next = p;
            r = p;
        }
    }
    void Insertlist(linklist& L, int x)
    {
        linklist p;
        p = L;
        linklist q;
        q = (linklist)malloc(sizeof(LNode));  //修改
        //q = (linklist)malloc(sizeof(linklist));
        while (p->next && p->next->data < x) //修改
        //while (p->next->data < x) 
        {
            p = p->next;
        }
        q->data = x;
        q->next = p->next;
        p->next = q;
    }
    void print(linklist L)
    {
        linklist p;
        p = L->next;
        while (p != NULL)
        {
            cout << p->data << " ";
            p = p->next;
        }
    }
    int main()
    {
        linklist L;
        int n, x;
        cin >> n;
        Initlist(L);
        creatlist(L, n);
        cin >> x;
        Insertlist(L, x);
        print(L);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月12日
  • 已采纳回答 4月4日
  • 创建了问题 3月28日

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题