<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="zh-Hans-CN">
	<id>https://wiki.riguz.com/index.php?action=history&amp;feed=atom&amp;title=Merge_sort</id>
	<title>Merge sort - 版本历史</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.riguz.com/index.php?action=history&amp;feed=atom&amp;title=Merge_sort"/>
	<link rel="alternate" type="text/html" href="https://wiki.riguz.com/index.php?title=Merge_sort&amp;action=history"/>
	<updated>2026-06-02T18:41:30Z</updated>
	<subtitle>本wiki上该页面的版本历史</subtitle>
	<generator>MediaWiki 1.42.3</generator>
	<entry>
		<id>https://wiki.riguz.com/index.php?title=Merge_sort&amp;diff=4022&amp;oldid=prev</id>
		<title>Riguz：​Riguz移动页面归并排序至Merge sort，不留重定向</title>
		<link rel="alternate" type="text/html" href="https://wiki.riguz.com/index.php?title=Merge_sort&amp;diff=4022&amp;oldid=prev"/>
		<updated>2024-01-18T09:18:28Z</updated>

		<summary type="html">&lt;p&gt;Riguz移动页面&lt;a href=&quot;/index.php?title=%E5%BD%92%E5%B9%B6%E6%8E%92%E5%BA%8F&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;归并排序（页面不存在）&quot;&gt;归并排序&lt;/a&gt;至&lt;a href=&quot;/Merge_sort&quot; title=&quot;Merge sort&quot;&gt;Merge sort&lt;/a&gt;，不留重定向&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;zh-Hans-CN&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;←上一版本&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2024年1月18日 (四) 09:18的版本&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;4&quot; class=&quot;diff-notice&quot; lang=&quot;zh-Hans-CN&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;（没有差异）&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;
&lt;!-- diff cache key wiki_db:diff:1.41:old-982:rev-4022 --&gt;
&lt;/table&gt;</summary>
		<author><name>Riguz</name></author>
	</entry>
	<entry>
		<id>https://wiki.riguz.com/index.php?title=Merge_sort&amp;diff=982&amp;oldid=prev</id>
		<title>imported&gt;Soleverlee：​以“对一个随机点的链表进行排序 归并排序（Merge sort）是建立在归并操作上的一种有效的排...”为内容创建页面</title>
		<link rel="alternate" type="text/html" href="https://wiki.riguz.com/index.php?title=Merge_sort&amp;diff=982&amp;oldid=prev"/>
		<updated>2015-03-27T08:58:31Z</updated>

		<summary type="html">&lt;p&gt;以“&lt;a href=&quot;/%E6%96%87%E4%BB%B6:Merge_sort_animation2.gif&quot; title=&quot;文件:Merge sort animation2.gif&quot;&gt;right|frame|对一个随机点的链表进行排序&lt;/a&gt; 归并排序（Merge sort）是建立在归并操作上的一种有效的排...”为内容创建页面&lt;/p&gt;
&lt;p&gt;&lt;b&gt;新页面&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[Image:Merge_sort_animation2.gif|right|frame|对一个随机点的链表进行排序]]&lt;br /&gt;
归并排序（Merge sort）是建立在归并操作上的一种有效的排序算法。该算法是采用分治法（Divide and Conquer）的一个非常典型的应用。&lt;br /&gt;
=算法描述=&lt;br /&gt;
#申请空间，使其大小为两个已经排序序列之和，该空间用来存放合并后的序列&lt;br /&gt;
#设定两个指针，最初位置分别为两个已经排序序列的起始位置&lt;br /&gt;
#比较两个指针所指向的元素，选择相对小的元素放入到合并空间，并移动指针到下一位置&lt;br /&gt;
#重复步骤3直到某一指针到达序列尾&lt;br /&gt;
#将另一序列剩下的所有元素直接复制到合并序列尾&lt;br /&gt;
=示例代码=&lt;br /&gt;
==Python==&lt;br /&gt;
&amp;lt;source lang=&amp;quot;python&amp;quot;&amp;gt;&lt;br /&gt;
def merge_sort(lst):&lt;br /&gt;
    if len(lst) &amp;lt;= 1:&lt;br /&gt;
        return lst&lt;br /&gt;
 &lt;br /&gt;
    def merge(left, right):&lt;br /&gt;
        merged = []&lt;br /&gt;
        while left and right:&lt;br /&gt;
            merged.append(left.pop(0) if left[0] &amp;lt;= right[0] else right.pop(0))&lt;br /&gt;
        while left:&lt;br /&gt;
            merged.append(left.pop(0))&lt;br /&gt;
        while right:&lt;br /&gt;
            merged.append(right.pop(0))&lt;br /&gt;
        return merged&lt;br /&gt;
 &lt;br /&gt;
    middle = int(len(lst) / 2)&lt;br /&gt;
    left = merge_sort(lst[:middle])&lt;br /&gt;
    right = merge_sort(lst[middle:])&lt;br /&gt;
    return merge(left, right)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
==Java==&lt;br /&gt;
&amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
public static int[] mergeSort(int[] arr){//归并排序 --递归&lt;br /&gt;
	if(arr.length==1){&lt;br /&gt;
		return arr;&lt;br /&gt;
	}&lt;br /&gt;
	int half = arr.length/2;&lt;br /&gt;
	int[] arr1 = new int[half];&lt;br /&gt;
	int[] arr2 = new int[arr.length-half];&lt;br /&gt;
	System.arraycopy(arr, 0, arr1, 0, arr1.length);&lt;br /&gt;
	System.arraycopy(arr, half, arr2, 0, arr2.length);&lt;br /&gt;
	arr1 = mergeSort(arr1);&lt;br /&gt;
	arr2 = mergeSort(arr2);&lt;br /&gt;
	return mergeSortSub(arr1,arr2);&lt;br /&gt;
}&lt;br /&gt;
 &lt;br /&gt;
private static int[] mergeSortSub(int[] arr1,int[] arr2){//归并排序子程序&lt;br /&gt;
	int[] result = new int[arr1.length+arr2.length];&lt;br /&gt;
	int i = 0;&lt;br /&gt;
	int j = 0;&lt;br /&gt;
	int k = 0;&lt;br /&gt;
	while(true){&lt;br /&gt;
		if(arr1[i] &amp;lt; arr2[j]){&lt;br /&gt;
			result[k] = arr1[i];&lt;br /&gt;
			if(++i&amp;gt;arr1.length-1){&lt;br /&gt;
				break;&lt;br /&gt;
			}&lt;br /&gt;
		}else{&lt;br /&gt;
			result[k] = arr2[j];&lt;br /&gt;
			if(++j&amp;gt;arr2.length-1){&lt;br /&gt;
				break;&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
		k++;&lt;br /&gt;
	}&lt;br /&gt;
	for(;i&amp;lt;arr1.length;i++){&lt;br /&gt;
		result[++k] = arr1[i];&lt;br /&gt;
	}&lt;br /&gt;
	for(;j&amp;lt;arr2.length;j++){&lt;br /&gt;
		result[++k] = arr2[j];&lt;br /&gt;
	}&lt;br /&gt;
	return result;&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Category:Algorithm]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Soleverlee</name></author>
	</entry>
</feed>