题目:已知存在两个非递减的有序链表List1和List2,现在需要你将两个链表合并成一个有序的非递增序列链表List3,请用C++编码实现。(所有链表均为单链表结构)

思路:此处链表是否都有表头并没有规定。

1:将链表List1和List2合并成一个非递减有序链表List3;

2:再将链表List3进行逆序,即可。

#include <iostream>
using namespace std;
typedef int ElemType;
typedef struct LNode
{
 ElemType data;
 struct LNode *next;
}LinkList;
//采用尾插法创建表
void CreateListR(LinkList *&L,ElemType a[],int n)
{
 LinkList *s,*r;//将数组中的数值存在结点s,再插入到链表L中
 int i;
 L=(LinkList *)malloc(sizeof(LinkList));//链表L头结点
 r=L;//起初指向链表头结点
 for(i=0;i<n;i++)
 {
  s=(LinkList *)malloc(sizeof(LinkList));
  s->data=a[i];
  r->next=s;
  r=s;
 }
 r->next=NULL;//结束标识
}

LinkList *Merge(LinkList *&L1,LinkList *&L2)
{
 if(L2==NULL)
  return L1;
 if(L1==NULL)
  return L2;
 LinkList *L3;
 //L3=(LinkList *)malloc(sizeof(LinkList));
 if(L1->data<=L2->data)
 {
  L3=L1;
  L3->next=Merge(L1->next,L2);
 }
 else
 {
  L3=L2;
  L3->next=Merge(L1,L2->next);
 }
 return L3;
}

LinkList *ListReverse(LinkList *&L)
{
 LinkList *s,*q,*p;
 //s指向逆序后的链表中的当前元素,q指向待逆序链表的当前元素,p指向待逆序链表中当前结点的下一个结点
 if(L==NULL||L->next==NULL)
  return L;
 else
 {
  //s=L;//以链表无头结点的逆序
  s=L->next;//s指向链表头结点的下一个结点
  p=s->next;
  s->next=NULL;
  while(p)
  {
   q=p->next;
   p->next=s;
   s=p;
   p=q;
  }
  //L=s;//p为NULL,s指向逆序元素的当前元素,即链表的第一个元素(若链表无表头,则注释掉这句)
        L->next=s;//若有,链表头结点下一个指向s
 }
 return L;
}
void DispList(LinkList *&L)
{
 LinkList *p=L->next;
 while(p)
 {
  cout<<p->data<<" ";
  p=p->next;
 }
 cout<<endl;
}
int main()
{
 ElemType a1[3]={1,2,3};
 ElemType a2[3]={2,3,4};
 LinkList *L1,*L2;
 int n=3;
 CreateListR(L1,a1,n);
    CreateListR(L2,a2,n);
 DispList(L1);
 DispList(L2);
    LinkList *L3;
 //L3=(LinkList *)malloc(sizeof(LinkList));
 L1=L1->next;//除去头结点
 //L2=L2->next;//除去头结点
    L3=Merge(L1,L2);//以链表1的头结点开始
 DispList(L3);
 L3=ListReverse(L3);
 DispList(L3);
 system("pause");
 return 0;
}

编程菜鸟的日记-初学尝试编程-易传媒笔试题(C++实现)的更多相关文章

  1. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习9

    #include <iostream> #include <fstream> #include <cstdlib> #include <string> ...

  2. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习8

    #include <iostream> #include <fstream> #include <cstdlib> const int SIZE=20; using ...

  3. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习7

    #include <iostream> #include <string> #include <cctype> using namespace std; int m ...

  4. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习6

    #include <iostream> #include <string> using namespace std; const int MSIZE=100; struct j ...

  5. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习5

    #include <iostream> using namespace std; const double N1=35000; const int N2=15000; const int ...

  6. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习4

    #include <iostream> using namespace std; const int strsize=30; const int BOPSIZE=5; void showm ...

  7. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习3

    #include <iostream> using namespace std; void showmenu(void) { cout<<"Please enter ...

  8. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习2

    #include <iostream> #include <cctype> using namespace std; const int MAXSIZE=10; int mai ...

  9. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第6章编程练习1

    #include <iostream>#include <cctype>using namespace std;int main(){ char ch; while((ch=c ...

随机推荐

  1. python函数系列之sorted()

    一. 有时候需要对List.Dict进行排序 二.用法:sorted(iterable, cmp=None, key=None, reverse=False) 三.参数说明: iterable:是可迭 ...

  2. 安装淘宝npm(cnpm)

    https://www.cnblogs.com/yominhi/p/7039795.html http://npm.taobao.org/ 初始化一个 mpvue 项目 现代前端开发框架和环境都是需要 ...

  3. 用Photoshop扭曲滤镜工具打造旋转的光束效果

    原文:https://www.w3cschool.cn/photoshopgjjc/dthfn1.html 教程与已往的不同,作者加上了一些新的步骤如锐化等,出来的效果也有所改进.大致过程:先用滤镜制 ...

  4. tomcat启动成功但是访问方面都是404

    1.开发环境与错误情况 开发环境是jdk1.7+maven+git+spring MVC+spring+mybatis+mysql. 楼主做小例子的时候发现,tomcat成功启动,但是访问主页,页面提 ...

  5. 10本Java架构师必读书籍

    1.大型网站系统与JAVA中间件实践 本书围绕大型网站和支撑大型网站架构的Java中间件的实践展开介绍. 从分布式系统的知识切入,让读者对分布式系统有基本的了解:然后介绍大型网站随着数据量.访问量增长 ...

  6. Nginx代理实现内网主机访问公网服务

    通过Nginx代理实现内网主机访问公网和接口服务 1.需求: m2.test.com为公司测试环境的微信测试域名,因为要调用微信服务接口需要访问外网,现通过Nginx代理现实此功能. 2.环境如下: ...

  7. python全栈开发day62-两表操作增删改查,外键,if else模板语法

    一.今日内容总结: day62 内容回顾: 1. django有关所有命令: pip install django==1.11.14 django-admin startproject 项目名称 cd ...

  8. Codeforces 965E Short Code 启发式合并 (看题解)

    Short Code 我的想法是建出字典树, 然后让后面节点最多的点优先向上移到不能移为止, 然后gg. 正确做法是对于当前的节点如果没有被占, 那么从它的子树中选出一个深度最大的点换到当前位置. 用 ...

  9. es6 promise对象

    function next(){ return new Promise( function( resolve, reject ){ var num =7 // Math.floor( Math.ran ...

  10. jquery.zclip.js粘贴功能

    jquery的粘贴插件: 如下是代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> ...