• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C++归并算法实例

C++归并算法实例

作者:G0561 字体:[增加 减小] 来源:互联网 时间:2017-05-28

G0561 通过本文主要向大家介绍了c++归并排序算法,归并排序c++,归并算法,归并排序算法,二分归并算法等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了C++归并算法。分享给大家供大家参考。具体如下:

/* 
 归并算法:把两个或两个以上的线性表合并在一起,形成一个新的线性表
 函数模版的基本使用
 程序意图:将两个相同类型的线性表元素排好序,然后将他们组合成一个排好的线性表 
*/
#include <iostream>
using namespace std;
const int n = 5; //5个元素 
//输出数据元素
template <class T1>
void OutPut(T1 out[(2*n)])
{ 
  for (int i=0; i<(2*n); i++)
  { 
  cout<<out[i]<<" ";
  }
  cout<<endl;
} 
//输入数据元素 
template <class T2>
void InPut(T2 in[n])
{
  cout<<"请输入5个数据元素:";
  for (int i=0; i<n; i++)
  { 
  cin>>in[i];
  cout<<" "; 
  }
  cout<<endl;
}
//模版函数 输入线性表元素并将其排序
template <class T3> 
void MySort(T3 a[2*n])
{
  int temp; //交换数据临时变量 
  //冒泡锚序 
  for (int i=0; i<2*n-1; i++)
  {
   for (int j=0; j<2*n-1-i; j++)
   {
    if (a[j]>a[j+1]) 
    {
    temp = a[j];
    a[j] = a[j+1];
    a[j+1] = temp; 
    }
   }
  }
}
//模版函数 归并 
template <class T> 
void MergeList(T La[n], T Lb[n], T Lc[(2*n)]) 
{
  int i = 0; //作为La的下标 
  int j = 0; //Lb下标
  int k = 0; //Lc下标 
  //将La Lb组合成在一起 
  while (i<n && j<n)
  {
   if (La[i] < Lb[j])
   {
    Lc[k] = La[i];
    k++;
    Lc[k] = Lb[j];
   }
   else
   {
    if (La[i] == Lb[j])
    {
     Lc[k] = La[i];
     k++;
     Lc[k] = Lb[j];
    }
    else
    {
     Lc[k] = Lb[j];
     k++;
     Lc[k] = La[i];
    }
   }
   //各下标往下移动 
   i++;
   j++;
   k++;
  } 
  //如果La中的数据没有取完,及La比Lb长,则将La剩下的元素插入Lc中 这里是进行扩展 
  while (i<=n)
  {
   Lc[k++] = La[i++];
  } 
  //如果Lb中的数据没有取完,及Lb比La长,则将Lb剩下的元素插入Lc中
  while (j<=n)
  {
    Lc[k++] = Lb[j++];
  } 
  //对组合好的元素进行排序 
  MySort(Lc); 
}
int main()
{
 int a1[n],a2[n], a[(2*n)];
 double b1[n], b2[n],b[(2*n)];
 char m1[n], m2[n], m[(2*n)];
 //输入数据 归并输出 
 /*InPut(a1);
 InPut(a2); 
 MergeList(a1,a2,a);
 OutPut(a); */
 InPut(m1);
 InPut(m2); 
 MergeList(m1,m2,m);
 OutPut(m); 
 system("pause");
 return 0;
} 

</div>

希望本文所述对大家的C++程序设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • c++ 快速排序算法【过程图解】
  • C++实现的归并排序算法详解
  • 详细总结C++的排序算法
  • C++实现自顶向下的归并排序算法
  • C++归并算法实例
  • C++归并排序算法实例
  • C++中的几种排序算法

相关文章

  • 2017-05-28C语言中socket相关网络编程函数小结
  • 2017-05-28详解C语言中const关键字的用法
  • 2017-05-28C++求四个正整数最大公约数的方法
  • 2017-05-28C语言游戏必备:光标定位与颜色设置的实现方法
  • 2017-05-28c++ 端口扫描程序实现案例
  • 2017-05-28利用C语言实现HashTable
  • 2017-05-28C语言 基本语法示例讲解
  • 2017-05-28Linux C 时间函数应用
  • 2017-05-28C++采用TLS线程局部存储的用法实例
  • 2017-05-28理解C++编程中的std::function函数封装

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C/C++中可变参数的用法详细解析
    • 详解C语言中getgid()函数和getegid()函数的区别
    • 详解设计模式中的中介者模式在C++编程中的运用
    • C++中Semaphore内核对象用法实例
    • C++多线程编程简单实例
    • C++ Vector用法深入剖析
    • socket多人聊天程序C语言版(二)
    • 浅谈关于指针作为参数并改变它的值的问题
    • C++实现广度优先搜索实例
    • 直观理解C语言中指向一位数组与二维数组的指针

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有