第一次归并:

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

23

8

19

33

15

6

27

↑             ↑

i     j

最开始i指向a[0],j指向a[1],比较a[0],a[1]大小,并进行swap

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

23

19

33

6

15

27

↑                 ↑

i      j

i指向j时候归并结束

第二次归并:

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

23

19

33

6

15

27

↑                                     ↑

i            j

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

23

19

33

6

15

27

↑            ↑

i            j

i向后移动,直到找到比j指向的数大的那个数,此时,i之前的数是两段数值中最小的数

j原来的位置标记为Index,j向后移动找到比此时i指向的数大的数.

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

33

6

15

27

↑                    ↑               ↑

i     index    j

则此时a[Index,j]之间的数小于a[i,index]之间的数,将此两段数值互换,得到

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

23

33

6

15

27

↑               ↑

i     j

互换以后需要调整i的位置,将i向后移动index-j个单位【i+=(j-index)】

找到第一个比j指向的数大的,即此时i指向j,第二次归并结束。

第三次归并:

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

19

23

33

6

15

27

↑                                                                               ↑

i                         j

重复上述步骤,在此归并中,第一次比较时i不动,j指向a[5]

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

8

19

23

33

6

15

27

↑                                                                               ↑                ↑

i                        index    j

交换a[index,j]和a[i,index]两段数据,i+=(j-index)

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

6

8

19

23

33

15

27

↑                                                                              ↑                                                          i                        j

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

6

8

19

23

33

15

27

↑                                                       ↑

i                                                          j

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

6

8

19

23

27

↑                                                         ↑             ↑

i                 index   j

swap(i,j,index)

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

6

8

19

23

33

27

↑                                                       ↑

i                  j

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

6

8

15

19

23

33

27

↑             ↑

i    j

此时j任然指向a[6],index也指向a[6],交换

a[0]

a[1]

a[2]

a[3]

a[4]

a[5]

a[6]

6

8

15

19

23

27

33

↑              ↑

i     j

i之后第一个比j指向的数大的数为33,此时i=j,归并结束

代码还没写完。。。。。脑子笨,感觉不大对,再改看看吧。pow这个函数总觉得用的不大对,这两天看看别人写的代码再找找思路看。

void in_palce_merge_sort(double* a,int n){
int index;
int edge=;
int i=;//第一段有序数组入口
int j=;//第二段有序数组入口
int inpoint=;
while(pow(,edge)<n){
while(a[i]<a[j]&&i<j) i++;
index=j;
while(a[j]<a[i]&&j<inpoint+pow(,edge)) j++;
swap(a[i],a[j],a[index]);
i+=(j-index);
if(i==j&&i<n){
i++; //此时往后移一位即新的有序数组的入口
j=i+pow(,edge); //等下考虑下2倍
inpoint=j; }
else if(i==n){
edge++;
i=;
j=pow(,edge);
inpoint=j;
}
}
}

关于swap(),个人想到的是需要一段临时空间作为暂存空间进行交换,如果这样的话感觉就失去原地归并的意义了,其他搜索到有手摇算法,等仔细研究下再来修改。

【原创】Algorithms:原地归并排序的更多相关文章

  1. STL:原地归并排序模板(InplaceMergeSort)

    原理:就是在归并排序上改进,以时间复杂度换空间复杂度,利用元素反转完成排序 具体过程如下: 具体操作看代码吧,应该没什么难度,主要是reverse要反转三次 typedef int Position; ...

  2. 【Algorithms】归并排序(merge sort)

    几个比较常见的排序算法里头,这个我是比较生疏的一个,有一天突然被问了一个问题是,归并排序最大的特点是什么,我才想起这个算法来.下午又看不进书啦,就实现一下,记下来. 归并排序采取的是分治策略,就是先将 ...

  3. Coursera Algorithms week3 归并排序 练习测验: Shuffling a linked list

    题目原文: Shuffling a linked list. Given a singly-linked list containing n items, rearrange the items un ...

  4. Coursera Algorithms week3 归并排序 练习测验: Counting inversions

    题目原文: An inversion in an array a[] is a pair of entries a[i] and a[j] such that i<j but a[i]>a ...

  5. Coursera Algorithms week3 归并排序 练习测验: Merging with smaller auxiliary array

    题目原文: Suppose that the subarray a[0] to a[n-1] is sorted and the subarray a[n] to a[2*n-1] is sorted ...

  6. java归并排序,单线程vs多线程

    一.什么是归并排序 归并排序又称合并排序,它是成功应用分治技术的一个完美例子.对于一个需要排序的数组A[0..n-1],归并排序把它一分为二:A[0..n/2-1]和A[n/2..n-1],并对每个子 ...

  7. 普林斯顿大学算法课 Algorithm Part I Week 3 归并排序 Mergesort

    起源:冯·诺依曼最早在EDVAC上实现 基本思想: 将数组一分为(Divide array into two halves) 对每部分进行递归式地排序(Recursively sort each ha ...

  8. 总结: Sort 排序算法

    排序总结 面试经验 硅谷某前沿小Startup面试时,问到的一个题目就是写一个快速排序算法.进而面试官问到了各种算法的算法复杂度,进而又问了Merge Sort 与 QuickSort 的优劣. 对排 ...

  9. 033.[转] Java 工程师成神之路 | 2019正式版

    Java 工程师成神之路 | 2019正式版 原创: Hollis Hollis 2月18日 https://mp.weixin.qq.com/s/hlAn6NPR1w-MAwqghX1FPg htt ...

随机推荐

  1. php变量的判空和类型判断

    (1)var_dump(); 判断一个变量是否已经声明并且赋值,并且打印类型和值 <?php $a; var_dump($a);//输出null <?php var_dump($a);// ...

  2. ODI 12.1.3发布,提升支持大数据的能力

    此次发布的ODI新版本,目的是更好的支持当前市场上的大数据平台. 大数据基因在不改变ODI工作效率的情况下,ODI增加了越来越多的数据源集成能力.ODI是在Oracle平台上标准的E-LT工具,事实上 ...

  3. poj1080 dp

    //Accepted 200 KB 0 ms //dp //dp[i][j]表示s1用前i个,s2用前j个字符能得到的最大分数 //dp[i][j]=max(dp[i-1][j]+score[s1[i ...

  4. hdu 2098

    ps:TLE一次....因为判断素数的时候没开方...作死.. 代码: #include "stdio.h" #include "math.h" int inp ...

  5. 关于GSMMAP分支cell_log扫描不正常问题的解决办法

    阔别多年,本周在KALI 2.0下重拾旧时趣味,可怎么折腾都未曾见ARFCN,迫不得已还刷了brust_ind分支 才达到目的.后经仔细翻阅官方文档发现此问题早有披露,解决方案也已经公布,逐分享给大家 ...

  6. A sample of procedure in using

  7. 黑马程序员——【Java基础】——面向对象(一)概述、类与对象、继承、抽象类、接口、多态、内部类

    ---------- android培训.java培训.期待与您交流! ---------- 一.面向对象概述 1.面向对象:是一个很抽象的概念,它相对面向过程而言,是一种程序设计的思想. 2.面向对 ...

  8. Smart210学习记录-------linux驱动中断

    Linux中断 Linux 的中断处理分为两个半部,顶半部处理紧急的硬件操作,底半部处理不紧急的耗时操作.tasklet 和工作队列都是调度中断底半部的良好机制,tasklet 基于软中断实现.内核定 ...

  9. Ecshop安装过程中的的问题:cls_image::gd_version()和不支持JPEG

    在安装Ecshop的时候,遇到两个问题: 1.Strict Standards: Non-static method cls_image::gd_version() should not be cal ...

  10. 设备、像素和点 、 9切片技术 、 颜色和外观 、 NavigationBar的美化

    1 TMessage项目的输入面板界面 1.1 问题 IOS中经常会使用到九切片技术对图片进行处理.本案例使用九切片技术完成Tmessage项目的输入板界面,如图-1所示: 图-1 1.2 方案 首先 ...