思想

归并排序(MERGE-SORT)是利用归并的思想实现的排序方法,该算法采用经典的分治(divide-and-conquer)策略(分治法将问题分(divide)成一些小的问题然后递归求解,而治(conquer)的阶段则将分的阶段得到的各答案"修补"在一起,即分而治之)。

分而治之

可以看到这种结构很像一棵完全二叉树,本文的归并排序我们采用递归去实现(也可采用迭代的方式去实现)。分阶段可以理解为就是递归拆分子序列的过程,递归深度为log2n。
可以看到这种结构很像一棵完全二叉树,本文的归并排序我们采用递归去实现(也可采用迭代的方式去实现)。分阶段可以理解为就是递归拆分子序列的过程,递归深度为log2n。

再来看看治阶段,我们需要将两个已经有序的子序列合并成一个有序序列,比如上图中的最后一次合并,要将[4,5,7,8]和[1,2,3,6]两个已经有序的子序列,合并为最终序列[1,2,3,4,5,6,7,8],来看下实现步骤。

代码实现

#include<iostream>
using namespace std;
int a[10] = {13,27,19,2,8,12,2,8,30,89};
int b[10];void Merge(int a[],int start,int mid,int end,int temp[]){//一个数组分成两个子数组(都是有序的)  用p1和p2来移动 利用临时数组排序 最后复制到原数组 //p1:start~mid,p2:mid+1~end int p1 = start; //以要进行排序的数组开头为起点 int p2 = mid+1;//以要进行排序的数组中间为起点 int pt = 0;//记录临时数组的下标 //两个子数组比较 放到临时数组 while(p1<=mid && p2<=end){if(a[p1]<a[p2]){temp[pt++] = a[p1++];}else{temp[pt++] = a[p2++];   }}//将左边子数组剩余元素填充进temp中while(p1<=mid){temp[pt++] = a[p1++];}//将右边子数组剩余元素填充进temp中while(p2<=end){temp[pt++] = a[p2++];}//把排好的数组移到原数组 for(int i=0;i<end-start+1;i++){a[start+i] = temp[i];}
}void MergeSort(int a[],int start,int end,int temp[]){int mid; if(start<end){mid = start+(end-start)/2;//左边归并排序,使得左子序列有序MergeSort(a,start,mid,temp);//右边归并排序,使得右子序列有序MergeSort(a,mid+1,end,temp);将两个有序子数组合并操作Merge(a,start,mid,end,temp);}
}int main(){int size = sizeof(a)/sizeof(int); MergeSort(a,0,size-1,b);for(int i=0;i<size;i++){cout<<a[i]<<" ";} cout<<endl;return 0;
} 

讲解:程序设计与算法(二)算法基础第五周分治-归并排序

图解来源

例题

Description

现有n个人的信息,每人的信息有:身份证号码、姓名、性别、住址。请你按身份证号码的的顺序进行升序排序。

Input

只有一个身份证信息库。第一个数是n(后台的n在1万到2万之间),接着有n个人的信息。

Ouput

按身份证号码升序输出n个人的信息。

Sample Input

5
34242119920526054X 陈小苗 男 三明
352421199205260545 肖燕 女 北京
382421198205260123 钱俩 男 广州
34252119920526054X 吴小苗 男 三明
342521199206260544 陈小燕 女 上海

Sample Output

身份证号:34242119920526054X,姓名:陈小苗,性别:男,住址:三明
身份证号:34252119920526054X,姓名:吴小苗,性别:男,住址:三明
身份证号:342521199206260544,姓名:陈小燕,性别:女,住址:上海
身份证号:352421199205260545,姓名:肖燕,性别:女,住址:北京
身份证号:382421198205260123,姓名:钱俩,性别:男,住址:广州

代码实现

Java

package 归并排序1895;import java.util.Scanner;public class Main {public static void main(String[] args) {// TODO Auto-generated method stubScanner in = new Scanner(System.in);int n = in.nextInt();Person[] p = new Person[n];for (int i = 0; i < n; i++) {p[i] = new Person(in.next(), in.next(), in.next(), in.next());}mergeSort(p,0,n-1);for(int i=0;i<n;i++) {System.out.println(p[i].toString());}in.close();}public static void mergeSort(Person[] p,int start,int end) {int mid;if(start<end) {mid = start+(end-start)/2;mergeSort(p,start,mid);mergeSort(p,mid+1,end);merge(p,start,mid,end);}}public static void merge(Person[] p,int start,int mid,int end) {int x1 = start;int x2 = mid+1;int x3 = 0;Person[] t = new Person[p.length];while(x1<=mid && x2<=end) {//System.out.println("下标为"+x1+"的身份证号为"+p1[x1].getId().toString());//System.out.println("下标为"+x2+"的身份证号为"+p1[x2].getId().toString());if(p[x1].getId().compareTo(p[x2].getId())<0)t[x3++] = p[x1++];elset[x3++] = p[x2++];}while(x1<=mid) {t[x3++] = p[x1++];}while(x2<=end) {t[x3++] = p[x2++];}for(int i=0;i<x3;i++) {p[start+i] = t[i];}}
}class Person {private String id,name,sex,city;public Person(String id, String name, String sex, String city) {super();this.id = id;this.name = name;this.sex = sex;this.city = city;}public String getId() {return id;}public void setId(String id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}public String getCity() {return city;}public void setCity(String city) {this.city = city;}@Overridepublic String toString() {return "身份证号:"+this.getId()+",姓名:"+this.getName()+",性别:"+this.getSex()+",住址:"+this.getCity();}}

C++

#include<iostream>
#include <string>
#include <stdlib.h>
using namespace std;
void mergeSort(struct Person p[],int start,int end);
void merge(struct Person p[],int start,int mid,int end);
struct Person{string id;string name;string sex;string city;
};
int main(){int n,i;struct Person p[20000];cin>>n;for(i=0;i<n;i++){cin>>p[i].id>>p[i].name>>p[i].sex>>p[i].city;}mergeSort(p,0,n-1);for(i=0;i<n;i++){cout<<"身份证号:"<<p[i].id<<",姓名:"<<p[i].name<<",性别:"<<p[i].sex<<",住址:"<<p[i].city<<endl;}return 0;
}
void mergeSort(struct Person p[],int start,int end){int mid;if(start<end){mid = start+(end-start)/2;mergeSort(p,start,mid);mergeSort(p,mid+1,end);merge(p,start,mid,end);}
}
void merge(struct Person p[],int start,int mid,int end){int x1 = start,x2 = mid+1,x3 = 0,i;struct Person t[20000];while(x1<mid && x2<=end){if(p[x1].id.compare(p[x2].id)<0)t[x3++] = p[x1++];elset[x3++] = p[x2++];}while(x1<=mid) {t[x3++] = p[x1++];}while(x2<=end) {t[x3++] = p[x2++];}for(i=0;i<x3;i++) {p[start+i] = t[i];}
}

【C++】归并排序-分治(图解+例题)相关推荐

  1. 算法笔记-归并排序、归并排序时间复杂度、例题

    1. 归并排序 1)整体就是一个简单递归,左边排好序.右边排好序.让其整体有序 2)让其整体有序的过程里用了外排序方法 3)利用master公式来求解时间复杂度 4)归并排序的实质,实质是减少了元素间 ...

  2. c语言分治算法之归并排序,分治算法之归并排序

    分治算法: 将一个规模为N的问题分解为K个规模较小的子问题,这些子问题互相独立且与原问题性质相同.求出子问题的解后进行合并,就可得到原问题的解. 一般步骤: 1.分解,将要解决的问题划分成若干规模较小 ...

  3. 排序算法-归并排序详细图解

    归并排序: 采用了分治策略 就是将原问题分解为一些规模较小的相似子问题,然后递归解决这些子问题,最后合并其结果作为原问题的解. 归并的核心思想 将两个有序的数组合并成一个大的有序的数组,通过递归把待排 ...

  4. CDQ分治入门 + 例题 Arnooks's Defensive Line [Uva live 5871]

    CDQ分治入门 简介 CDQ分治是一种特别的分治方法,它由CDQ(陈丹琦)神犇于09国家集训队作业中首次提出,因此得名.CDQ分治属于分治的一种.它一般只能处理非强制在线的问题,除此之外这个算法作为某 ...

  5. 归并排序(图解配代码)

    归并排序 递归 证书学习归并排序之前,我们得先学习一下递归算法. 定义: ​ 定义方法时,在方法内部调用方法本身,称之为递归. public void show(){System.out.printl ...

  6. 分层图(图解+例题)

    分层图 分层图多用于求最短路径,但是最短路径中可以有k条边的权值为0. 既然可以k条边为0,那么对于k条边的选取就是个问题. 所以有了分层图的概念. 对于每个点都可以选择下一条边是否赋予权值为0,那么 ...

  7. 算法 摩尔投票算法(图解例题)

    摩尔投票算法 摩尔投票算法也叫多数投票算法 摩尔投票法,解决的问题是如何在任意多的候选人中,选出票数超过一半的那个人.注意,是超出一半票数的那个人. 假设投票是这样的,[A, C, A, A, B], ...

  8. 设计模式之职责链模式(图解+例题+java源码)

    模式定义 职责链模式(Chain of Responsibility Pattern):避免请求发送者和接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连成一条链,并且沿着这条链传递请求,直到 ...

  9. python选择排序算法图解_python基本算法之实现归并排序(Merge sort)

    0.前言 评判一个算法的好坏的标准: 时间复杂度 空间复杂度 1.归并排序算法是什么? 冒泡排序(Bubble Sort)是一种建立在归并操作上面的一种有效的排序算法,由John von neuman ...

  10. 【算法与数据结构】分治(Divid Conquer)算法——以快排,归并排序,二分查找为例

    背景 虽然平时工作涉及的主要内容是NLP相关,但是在处理数据,以及实现相关NLP的过程中难免不遇上一些基本算法的内容.分治就是一种比较好的算法思维,有必要对他进行深入了解和熟练使用. 算法内容 所谓分 ...

最新文章

  1. 怎么知道 网站是否直接明文保存密码_忘记账号密码 浏览器记住了 怎么找回密码?...
  2. 孙立岩 python-basic: 用于学习python基础的课件(十三十四 十五)
  3. linux字符串编码转换函数,Linux C++ 字符串 编码识别、编码转换
  4. Android 平台的Crash崩溃捕获-全
  5. 网络工程师交换试验手册之十八:SWITCH的基本配置
  6. 《C++ Primer》7.1.3节练习
  7. 特斯拉再回应自燃事件:正在权威部门主导下进行调查 暂未有初步结论
  8. 美检方或起诉刘强东;百度对呛微信规则;澳洲调查 Facebook | 极客头条
  9. 如何解决GBK的编码的文件中的中文转换成为UTF-8编码的文件而且不乱码
  10. java2实用教程第四版pdf下载_Java 2实用教程(第4版)
  11. 微信小程序demo汇总
  12. WIN10 下 autocad2006 及其他版本打开文件多窗口不能一个窗口的解决办法
  13. 网络云存储技术Windows server 2012 (项目六 存储服务器的数据备份与还原 windows Server Backup)
  14. 2020身高体重标准表儿童_2020最新宝宝身高体重标准表(中国标准版)
  15. 计算机信息心得体会作文50字,考试感想作文50字5篇
  16. 张邦鑫:组织文化 - 价值观打造方法论初步
  17. 《互联网时代》第二集·浪潮
  18. bytebuddy之advice详解 注解详解
  19. 【PAT甲级】1142 Maximal Clique
  20. 基类与派生类对象的关系 派生类的构造函数

热门文章

  1. 微信安装包11年膨胀575倍,UP主:“98%的文件是垃圾”;苹果应用商店被曝大量色情App;四大科技巨头呼吁废除闰秒|极客头条
  2. UCI数据集详解及其数据处理(附148个数据集及处理代码)
  3. vivo手机刷鸿蒙教程,vivo手机怎么刷机_vivo手机刷机全教程
  4. 原型设计之Axure RP
  5. 10KV高压电缆的直流耐压究竟是多少?
  6. python代码文件生成exe文件
  7. Android 代码中执行adb shell命令
  8. 一键备份服务器文件夹权限,教大家一键设置局域网共享文件夹权限
  9. Soulver 3 for Mac(Mac计算器软件)
  10. webstorm主题设置