关淳 2022-10-04 19:48 采纳率: 73.9%
浏览 73
已结题

合并两个单调不递减链表

这么写为什么不对啊 有希望改嘛 错在哪里了 初学者自学的 别提醒我30个字了

  • 写回答

6条回答 默认 最新

  • _GX_ 2022-10-04 20:43
    关注
    #include <bits/stdc++.h>
    
    using namespace std;
    
    typedef int ElemType;
    
    typedef struct Link {
      ElemType Elem;
      struct Link *next;
    } link;
    
    link *CreatLink(int n) {
      link *head = (link *)malloc(sizeof(link));
      head->next = NULL;
      //创立头节点
      link *temp = head;
      //创立头指针指向头节点
      while (n--) {
        link *a = (link *)malloc(sizeof(link));
        scanf("%d", &a->Elem);
        a->next = NULL;
        temp->next = a;
        temp = a;
      }
      return head;
    }
    
    link *merge(link *l1, link *l2) {
      if (l1 == NULL)
        return l2;
      if (l2 == NULL)
        return l1;
      l1 = l1->next;
      l2 = l2->next;
      link *head = (link *)malloc(sizeof(link));
      head->next = NULL;
      //新头节点
      link *tail = head;
      //新头指针
      while (l1 && l2) {
        if (l1->Elem <= l2->Elem) {
          tail->next = l1;
          l1 = l1->next;
        } else {
          tail->next = l2;
          l2 = l2->next;
        }
        tail = tail->next;
      }
      //循环操作
    
      if (l1)
        tail->next = l1;
      if (l2)
        tail->next = l2;
      //最后必有一个原链表还剩下一串链表
    
      return head;
    }
    
    int main() {
      link *l1, *l2, *l3;
      int n1, n2;
    
      cout << "输入A链表表长及元素\n";
      scanf("%d", &n1);
      l1 = CreatLink(n1);
    
      cout << "输入B链表表长及元素\n";
      scanf("%d", &n2);
      l2 = CreatLink(n2);
    
      l3 = merge(l1, l2);
      cout << "合并后的C表为:\n";
    
      link *p = l3->next;
      while (p) {
        printf("%d ", p->Elem);
        p = p->next;
      }
    
      return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月4日
  • 已采纳回答 10月4日
  • 赞助了问题酬金15元 10月4日
  • 创建了问题 10月4日

悬赏问题

  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd