MergingSort
- 递归排序的两种实现
<script type="text/javascript">
//归并排序(递归实现)
//思想:堆排序利用了完全二叉树的性质,但是比较麻烦
//而归并排序则是直接利用构造一颗完全二叉树
//实现策略:先对数据分组,分到只有一个元素是:拷贝数组的元素到本次函数的
//SR数组中,归并SR到arr2中,arr2指向上层函数的SR数组
//时间复杂度:归并的次数是完全二叉树的高度,同时每次都需要对两个序列
//进行排序O(n),所以总的时间复杂度为O(nlogn)
//空间复杂度O(n+logn) n是数组 logn是递归需要的空间
//稳定性:稳定
function MergingSort(obj)
{
MSort(obj.data,obj.data,1,obj.length);
}
//拆分序列
//下层的数据SR归并到arr2中,arr2中本层函数的SR
function MSort(arr1,arr2,s,t)
{
var m;
var SR=[];
//SR用来存放下层函数归并的数据
if(s==t)
arr2[s]=arr1[s];
else
{
m=Math.floor((s+t)/2);
MSort(arr1,SR,s,m);
MSort(arr1,SR,m+1,t);
//console.log(SR);
//打印归并的过程
Merge(arr2,SR,s,m,t);
//console.log(arr2);
//打印归并的过程
}
}
//归并排序的非递归实现
//时间复杂度:O(nlogn)
//空间复杂度:O(n)
//稳定性:稳定
function MergingSort1(obj)
{
var k=1;
//k代表每次归并的序列长度
var arr1=[];
while(k<obj.length)
{
//执行两次是为了把数据放放到元素中
//归并arr中的数据到arr1
MergePass(obj.data,arr1,k,obj.length);
k=2*k;
//归并arr1到arr
MergePass(arr1,obj.data,k,obj.length);
k=2*k;
}
}
//如何进行分组
//k代表归并的序列长度 n代表的是总序列的长度
function MergePass(arr,arr1,s,n)
{
var i=1;
//最少还有两个可以归并
while(i<=n-2*s+1)
{
Merge(arr1,arr,i,i+s-1,i+2*s-1);
i+=(2*s);
}
//当还有两个分组时
if(i<n-s+1)
Merge(arr1,arr,i,i+s-1,n);
else
{//最多只有一个分组时
for(i;i<=n;i++)
{
arr1[i]=arr[i];
}
}
}
function Merge(arr1,arr2,s,m,t)
{
var i,j;
//把s到t的元素按从小的到大的顺序存放到数组中
for(i=s,j=m+1;s<=m && j<=t;i++)
{
if(arr2[s]<arr2[j])
arr1[i]=arr2[s++];
else
arr1[i]=arr2[j++];
}
if(s<=m)
{
for(;s<=m;s++)
{
arr1[i++]=arr2[s];
}
}
if(j<=t)
{
for(;j<=t;j++)
{
arr1[i++]=arr2[j];
}
}
}
var obj={
data:[0,3,11,5,2,4,3,11,5],
length:8
}
MergingSort(obj);
console.log(obj.data);
MergingSort1(obj)
console.log(obj.data);
</script>
MergingSort的更多相关文章
- Java程序员必须掌握的8大排序算法
分类: 1)插入排序(直接插入排序.希尔排序)2)交换排序(冒泡排序.快速排序)3)选择排序(直接选择排序.堆排序)4)归并排序5)分配排序(基数排序) 所需辅助空间最多:归并排序所需辅助空间最少:堆 ...
- Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法
Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...
- [转]Java 常用排序算法/程序员必须掌握的 8大排序算法
本文转自:http://www.cnblogs.com/qqzy168/archive/2013/08/03/3219201.html 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插 ...
- java SE 常用的排序算法
java程序员会用到的经典排序算法实现 常用的排序算法(以下代码包含的)有以下五类: A.插入排序(直接插入排序.希尔排序) B.交换排序(冒泡排序.快速排序) C.选择排序(直接选择排序.堆排序) ...
- Java 常用排序算法/程序员必须掌握的 8大排序算法
Java 常用排序算法/程序员必须掌握的 8大排序算法 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配 ...
- 面试常考的数据结构Java实现
1.线性表 2.线性链表 3.栈 4.队列 5.串 6.数组 7.广义表 8.树和二叉树 的结点),并且,二叉树的子树有左右之分,其次序不能任意颠倒. 二叉树的性质: :在二叉树的第 i 层上至多有2 ...
- Java程序员必知的8大排序算法
8种排序之间的关系 直接插入排序 (1)基本思想:在要排序的一组数中,假设前面(n-1)[n>=2] 个数已经是排 好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数 也是排好顺序的.如 ...
- 排序算法 Java实现版
8种排序之间的关系: 1. 直接插入排序 (1)基本思想: 在要排序的一组数中,假设前面(n-1)[n>=2] 个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序 ...
- java实现8种排序算法(详细)
八种排序分别是:直接插入排序.希尔排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序. 希尔排序在时间性能上优于直接插入排序,但希尔排序是一种不稳定排序. 快速排序的时间性能也优于冒泡 ...
随机推荐
- [BFS]P1434 [SHOI2002]滑雪
P1434 [SHOI2002]滑雪 Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者 ...
- Python转义字符中'\'的个数问题
Python转义字符中''的个数问题 如果字符串里面有很多字符都需要转义,就需要加很多\,为了简化,Python还允许用r' '或者r" "表示''或" "内部 ...
- 安装Dynamics CRM Report出错二
提示账户不是本地用户且不受支持 找到所需的服务,使用域管理员用户更改服务运行的账户.应用和确定 重新启动服务 重新运行安装向导,环境验证成功
- PAT A1032 Sharing
题意:给出两条链表的首地址以及若干节点的地址,数据,下一个节点的地址,求两条链表的首个共用节点的地址.如果两条链表没有共用节点,则输出-1.思路步骤1:由于地址的范围很小,因此可以直接用静态链表,但是 ...
- Python:函数解释(面向过程)
1. 函数概述 在编程的语境下,函数 (function) 是指一个有命名的.执行某个计算的语句序列 (sequence of statements) .函数可以针对某类问题建立了通用解决步骤(算法) ...
- 前端面试回顾(1)---javascript的面向对象
前言 前一阵面试,过程中发现问到一些很基础的问题时候,自己并不能很流畅的回答出来.或者遇到一些基础知识的应用,由于对这些点理解的不是很深入,拿着笔居然什么都写不出来,于是有了回顾一下这些基础知识的想法 ...
- 数据结构之Queue | 让我们一块来学习数据结构
前面的两篇文章分别介绍了List和Stack,下面让我们一起来学习Queue 数据结构之List | 让我们一块来学习数据结构 数据结构之Stack | 让我们一块来学习数据结构 队列的概况 队列是一 ...
- nginx+nginx-upsync-module实现配置动态更新
模块微博开源:https://github.com/weibocom/nginx-upsync-module#upsync 实现方案: nginx+consul nginx+etcd Installa ...
- .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程
本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...
- 手把手教你SonarQube入门安装与使用
简介 Sonar (SonarQube)是一个开源平台,用于管理源代码的质量. Sonar 不只是一个质量数据报告工具,更是代码质量管理平台. 支持Java, C#, C/C++, PL/SQL, C ...