Katelisa 2022-03-20 20:02 采纳率: 86.4%
浏览 473
已结题

下面的函数能够实现在一个带头结点的递增有序的单链表中插入一个元素x,使得单链表仍然保持有序吗?该怎么该

int InsertListInOrder(LinkList L, ElemType x)
{ Node *s;

s=(Node *)malloc(sizeof(Node));
if (s==NULL) return ERROR;
s->data=x;
L=L->next;
while ( L!=NULL )
    if ( x>L->data )
        L=L->next;
    else
    {   s->next=L->next;
        L->next=s;
    }
return OK;

}

  • 写回答

1条回答 默认 最新

  • 魔法自动机 2022-03-22 11:27
    关注

    用多一个指针pre记录L当前遍历的上一个结点,遇到L>=x的时候,就把s插入到pre和L中间。

    int InsertListInOrder(LinkList L, ElemType x)
    {
        Node *s, *pre;
        s = (Node *)malloc(sizeof(Node));
        if (s == NULL) return ERROR;
        s->data = x;
        pre = L;
        L = L->next;
        while (L != NULL) {
            if (x > L->data) {
                pre = L;
                L = L->next;
            }
            else{
                //把s插入到pre和L中间
                s->next = L;
                pre->next = s;
                return OK;
            }
        }
        //这里考虑L中没有大于等于x情况,也就是插入到末尾
        s->next = L;
        pre->next = s;
        return OK;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)