
目录
定义:归并排序是建立在归并操作上的一种有效,稳定的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。

思路:
1)首先将给定的数组{51, 46, 20, 18, 95, 67, 82, 30}一分为二,直到每个数组的长度等于1
{51, 46, 20, 18} {95, 67, 82, 30}
{51, 46} {20, 18} {95, 67} {82, 30}
{51} {46} {20} {18} {95} {67} {82} {30}
2)两两比较进行交换{46, 51} {18, 20} {67, 95} {30, 82}
3)最后进行合并得到排序后的数组{18, 20, 30, 46, 51, 67, 82, 95}
整体的递归思路就是:
import java.util.Arrays;
public class MergeSort {
public static int sum = 0;
public static void main(String[] args) {
int[] a = {51, 46, 20, 18, 95, 67, 82, 30};
mergeSort(a, 0, a.length - 1);
System.out.println(Arrays.toString(a));
}
public static void mergeSort(int[] a, int left, int right) {
//二分
int mid = (left + right) / 2;
//拆分过程就是递归,需要不断进行递归,减小子数组的规模,最终减小到每个数组的规模为1或者为0
if (left < right) {
mergeSort(a, left, mid);
mergeSort(a, mid + 1, right);
merge(a, left, mid, right);
}
}
public static void merge(int[] a, int left, int mid, int right) {
int[] temp = new int[right - left + 1];//临时数组,用来进行归并
int i = left, j = mid + 1, k = 0;//左半段用i指向,右半段用j指向,temp中用k指向
while (i <= mid && j <= right) {
if (a[i] < a[j]) {
//如果左边的a[i]小于右边的a[j],就放到数组的第k个,k和i自增
temp[k++] = a[i++];
} else {
//否则,就把右边的第j个放到数组的第k个,k和j自增
temp[k++] = a[j++];
}
}
while (i <= mid) temp[k++] = a[i++];//如果左边在循环比较后还有剩余,就放到k中、
while (j <= right) temp[k++] = a[j++];//如果剩余直接放到k中
for (int l = 0; l < temp.length; l++) {
//让temp数组放到左半段和右半段有序的数据
a[left + l] = temp[l];
}
}
}
运行流程:
1)首先设定一个分界值,通过该分界值将数组分成左右两部分。
2)将大于或等于分界值的数据集中到数组右边,小于分界值的数据集中到数组的左边。此时,左边部分中各元素都小于分界值,而右边部分中各元素都大于或等于分界值。
3)左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。
4)重复上述过程,可以看出,这是一个递归定义。通过递归将左侧部分排好序后,再递归排好右侧部分的顺序。当左、右两个部分各数据排序完成后,整个数组的排序也就完成了。

1)首先确定left、rigeht和基准点temp
2)当i(left) 和 j(right)相等的时候就结束循环
3)在循环中再次循环找出a[j]小于temp的时候把a[j]赋给a[i++],以及找出a[i]大于temp的时候把a[i]赋给a[j--]
4)不断递归进行排序
import java.util.Arrays;
public class quickSortDemo {
public static void main(String[] args) {
int[] a = {49, 38, 65, 97, 76, 13, 27, 49};
quickSort(a, 0, a.length - 1);
System.out.println(Arrays.toString(a));
}
public static void quickSort(int[] a, int left, int right) {
if (left > right) return;//区间无效不需要递归
int i = left, j = right, temp = a[left];//temp为基准点
while (i != j) {
while (a[j] >= temp && j > i) j--;//一直循环找a[j]小于temp的时候
if (j > i) a[i++] = a[j];//将a[j]赋给a[i++]
while (a[i] <= temp && i < j) i++;//循环找a[i]大于temp的时候
if (i < j) a[j--] = a[i];//将a[i]赋给a[j--]
}
a[i] = temp;//将基准点的元素放到a[i]处
quickSort(a, left, i - 1);//已经确定i为基准点所以right就位i - 1
quickSort(a, i + 1, right);//已经确定i为基准点所以left就位i + 1
}
}

我需要用任何语言编写一个算法,根据3个因素对数组进行排序。我以度假村为例(如Hipmunk)。假设我想去度假。我想要最便宜的地方、最好的评论和最多的景点。但是,显然我找不到在所有3个中都排名第一的方法。Example(assumingthereare20importantattractions):ResortA:$150/night...98/100infavorablereviews...18of20attractionsResortB:$99/night...85/100infavorablereviews...12of20attractionsResortC:$120/night
我正在尝试按Rails相关模型中的字段进行排序。我研究的所有解决方案都没有解决如果相关模型被另一个参数过滤?元素模型classItem相关模型:classPriority我正在使用where子句检索项目:@items=Item.where('company_id=?andapproved=?',@company.id,true).all我需要按相关表格中的“位置”列进行排序。问题在于,在优先级模型中,一个项目可能会被多家公司列出。因此,这些职位取决于他们拥有的company_id。当我显示项目时,它是针对一个公司的,按公司内的职位排序。完成此任务的正确方法是什么?感谢您的帮助。PS-我
我正在构建一个小部件来显示奥运会的奖牌数。我有一个“国家”对象的集合,其中每个对象都有一个“名称”属性,以及奖牌计数的“金”、“银”、“铜”。列表应该排序:1.首先是奖牌总数2.如果奖牌相同,按类型分割(金>银>铜,即2金>1金+1银)3.如果奖牌和类型相同,则按字母顺序子排序我正在用ruby做这件事,但我想语言并不重要。我确实找到了一个解决方案,但如果感觉必须有更优雅的方法来实现它。这是我做的:使用加权奖牌总数创建一个虚拟属性。因此,如果他们有2个金牌和1个银牌,加权总数将为“3.020100”。1金1银1铜为“3.010101”由于我们希望将奖牌数排序为最高的,因此列表按降序排
例如,假设我有一个名为Products的模型,并且在ProductsController中,我有以下代码用于product_listView以显示已排序的产品。@products=Product.order(params[:order_by])让我们想象一下,在product_listView中,用户可以使用下拉菜单按价格、评级、重量等进行排序。数据库中的产品不会经常更改。我很难理解的是,每次用户选择新的order_by过滤器时,rails是否必须查询,或者rails是否能够以某种方式缓存事件记录以在服务器端重新排序?有没有一种方法可以编写它,以便在用户排序时rails不会重新查询结果
有没有办法快速将表格格式的ruby哈希打印到文件中?如:keyAkeyBkeyC...1232343451253474456...其中散列的值是不同大小的数组。还是使用双循环是唯一的方法?谢谢 最佳答案 试试我写的这个gem(在表中打印散列、ruby对象、ActiveRecord对象):http://github.com/arches/table_print 关于ruby-如何以表格格式快速打印Ruby哈希值?,我们在StackOverflow上找到一个类似的问题:
我有一个对象如下:[{:id=>2,:fname=>"Ron",:lname=>"XXXXX",:photo=>"XXX"},{:id=>3,:fname=>"Dain",:lname=>"XXXX",:photo=>"XXXXXXX"},{:id=>1,:fname=>"Bob",:lname=>"XXXXXX",:photo=>"XXXX"}]我想按fname排序,不区分大小写,所以它会导致编号:1,3,2我该如何排序?我正在尝试:@people.sort!{|x,y|y[:fname]x[:fname]}但这没有任何效果。 最佳答案
有人可以告诉我如何根据自定义字符串对嵌套数组进行排序吗?比如有没有办法排序:[['Red','Blue'],['Green','Orange'],['Purple','Yellow']]“橙色”、“黄色”,然后是“蓝色”?最终结果如下所示:[['Green','Orange'],['Purple','Yellow'],['Red','Blue']]它不是按字母顺序排序的。我很想知道我是否可以定义要排序的值以实现上述目标。 最佳答案 sort_by对于这种排序总是非常方便:a=[['Red','Blue'],['Green','Ora
我有以下现有的Dog对象数组,它们按age属性排序:classDogattr_accessor:agedefinitialize(age)@age=ageendenddogs=[Dog.new(1),Dog.new(4),Dog.new(10)]我现在想插入一条新的狗记录,并将它放在数组中的正确位置。假设我想插入这个对象:another_dog=Dog.new(8)我想把它插入到数组中,让它成为数组中的第三项。这是一个人为的示例,旨在演示我特别想如何将一个项目插入到现有的有序数组中。我意识到我可以创建一个全新的数组并重新对所有对象进行排序,但这不是我的目标。谢谢!
我有一个这样的哈希{55=>{:value=>61,:rating=>-147},89=>{:value=>72,:rating=>-175},78=>{:value=>64,:rating=>-155},84=>{:value=>90,:rating=>-220},95=>{:value=>39,:rating=>-92},46=>{:value=>97,:rating=>-237},52=>{:value=>73,:rating=>-177},64=>{:value=>69,:rating=>-167},86=>{:value=>68,:rating=>-165},53=>{:va
如何在ruby中先根据值然后根据键对散列进行排序?例如h={4=>5,2=>5,7=>1}将排序为[[7,1],[2,5],[4,5]]我可以根据值进行排序h.sort{|x,y|x[1]y[1]}但我不知道如何根据值进行排序,然后在值相同时键入 最佳答案 h.sort_by{|k,v|[v,k]}这使用了Array的事实混入Comparable并定义逐元素。注意上面等价于h.sort_by{|el|el.reverse}相当于h.sort_by(&:reverse)这可能会或可能不会更具可读性。如果你知道Hashes一般都是先