1. 程式人生 > >分治演算法排序(C++版)

分治演算法排序(C++版)

分治排序:

把一個數組分成兩個陣列,然後在把這兩個陣列再各自分成兩個陣列,直到陣列有兩個數,然後比較這兩個數,並且合併,排序。


就是上面這個樣子 的。。

不說了上程式碼(c++版):

/**
* name:分治演算法
* time:15/8/9 14:25
* environment: ubuntu 14.04,sublime text 3
*/
#include <iostream>
using namespace std;

/*
* 列印陣列
*/
void printArray(int array[],int length)
{
	for (int i = 0; i < length; ++i)
	{
		cout << array[i] << endl;
	}
}

/*
* 一個數組從中間分成兩個有序陣列
* 把這兩個有序數組合併成一個有序陣列
*/
void merge(int array[],int first,int center,int end)
{

	int n1 = center - first + 1;
	int n2 = end - center;
	int L[n1+1];
	int R[n2+1];
	for(int i = 0; i < n1; i++ )
	{
		L[i] = array[first+i];     //得到前面一部分陣列
	}
	//printArray(L,n1);
	for(int j = 0; j < n2; j++ )
	{
		R[j] = array[center+j+1]; //得到後面一部分陣列
	}
	//printArray(R,n2);
	L[n1] = 1000;    //設定哨兵
	R[n2] = 1000;	 //設定哨兵
	//cout << "R[5] =" << R[4] << endl;
	int k1 = 0;
	int k2 = 0;
	for (int k = first; k <= end; ++k)    //把得到的兩個陣列進行排序合併
	{	
		//cout << L[k1] <<endl;
		//cout << R[k2] <<endl;
		if(L[k1] <= R[k2])
		{	
			//cout << L[k1] <<endl;
			array[k] = L[k1];
			//cout << array[k] << endl;
			//cout << "k1 =" << k1 << endl;
			k1 = k1 + 1; 
		}else{
			//cout << R[k2] <<endl;
			array[k] = R[k2];
			//cout << array[k] << endl;
			//cout << "k2 =" << k2 << endl;
			k2 = k2 + 1; 
		}
		//cout << array[k] <<endl;
	}
	//printArray(array,10);
}

/*
* 分治演算法
* 把一個數組從中間分成分開
* 然後進行排序
*/
void merge_sort(int array[],int first,int end)  
{
	if(first < end){
		int center = (first + end)/2;     //得到中間數
		merge_sort(array,first,center);   
		merge_sort(array,center+1,end);
		merge(array,first,center,end);
	}
}

int main(int argc, char const *argv[])
{
	int array[10] = {0,6,1,2,3,7,8,9,4,5};
	//merge(array,0,4,9);
	merge_sort(array,0,9);
	printArray(array,10);
	//int center = (0 + 9)/2;
	//cout << "center" << center << endl;
	//cout << "hello";
	return 0;
}


相關推薦

分治演算法排序C++

分治排序: 把一個數組分成兩個陣列,然後在把這兩個陣列再各自分成兩個陣列,直到陣列有兩個數,然後比較這兩個數,並且合併,排序。 就是上面這個樣子 的。。 不說了上程式碼(c++版): /** * name:分治演算法 * time:15/8/9 14:25 * envi

基數排序C++

假設原來有一串數值如下所示: 73, 22, 93, 43, 55, 14, 28, 65, 39, 81 首先根據個位數的數值,在走訪數值時將它們分配至編號0到9的桶子中: 0 1 81 2 22 3 73 93 43 4 14 5 55 65 6 7 8 28 9 39

資訊學奧賽一本通C++第二部分 基礎演算法 第二章 資料排序

第二章 資料排序 T1310 : 車廂重組 時間限制: 1000 ms 記憶體限制: 65536 KB 【題目描述】   在一箇舊式的火車站旁邊有一座橋,其橋面可以繞河中心的橋墩水平旋轉。一個車站的職工發現橋的長度最多能容納兩節車廂,如果將橋旋轉180180

常用的排序演算法詳解C#

只要是搞程式設計的演算法、資料結構、作業系統、計算機組成原理這些東西都會有用到,就像醫生給人治病一樣,只有瞭解了人的內部機理、運作機制,才能很好的做到對症下藥,藥到病除。而上面所說的那些計算機理論課就好像人的內部機理一樣,我們往往都把這些東西給忽略了,而把更多的精力放在具體的程式語言實現上,當然我也是這樣,

分治演算法C++

#include<iostream>using namespace std;  void printArray(int array[],int length)  {      for (int i = 0; i < length; ++i)      {  

常見排序演算法彙總C++實現

插入排序 #include<iostream> using namespace std; /* 插入排序的細節講解與複雜度分析 時間複雜度O(N ^ 2),額外空間複雜度O(1) */ void InsertSort(int *arr, int length) { int i,

前端演算法之快速排序JS

快排 1.基本原理:快速排序的基本思想:通過一趟排序將待排記錄分隔成獨立的兩部分,其中一部分記錄的關鍵字均比另一部分的關鍵字小,則可分別對這兩部分記錄繼續進行排序,以達到整個序列有序。 2.演算法實現: <1>.從數列中挑出一個元素,稱為 “基準”(pivot);

前端演算法之簡單排序JS

1.簡單排序 1.工作原理: 首先在未排序序列中找到最小(大)元素,存放到已排序序列的起始位置,然後再從剩餘的未排序的序列中繼續尋找最小(大)元素,然後放到已排序序列的末尾。以此類推,直到所有的元素均被排完。 2.演算法描述和實現 var arr=[3,2,5,8,0,4

資訊學奧賽一本通C++第二部分 基礎演算法 第一章 高精度計算

第一章 高精度計算 模板在最後。 T1307 : 高精度乘法 時間限制: 1000 ms 記憶體限制: 65536 KB 【題目描述】 【輸入】 【輸出】 【輸入樣例】 【輸出樣例】 【答案&程式碼】 T1308 : 高精除 時間限制:

java實現各種排序演算法(包括氣泡排序,選擇排序,插入排序,快速排序簡潔)及效能測試

1、氣泡排序是排序裡面最簡單的了,但效能也最差,數量小的時候還可以,數量一多,是非常慢的。      它的時間複雜度是O(n*n),空間複雜度是O(1)      程式碼如下,很好理解。 public static void bubbleSort(int[] arr)

資訊學奧賽一本通C++ 第二部分 基礎演算法 第八章 廣度優先搜尋算

//1329 【例8.2】細胞//編寫過程中,發現輸入資料用整數無法讀取,要採用字串形式//核心思路,將非零數字字元改成0字元 //將程式碼修改,提交AC #include <stdio.h>int n,m,next[][2]={{1,0},{-1,0},{0,1},{0,-1}};char a[

八大排序演算法之一直接插入排序C語言

概述 排序有內部排序和外部排序,內部排序是資料記錄在記憶體中進行排序,而外部排序是因排序的資料很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存。 我們這裡說說八大排序就是內部排序。     當n較大,則應採用時間複雜度為O(nlog2n)的排序方法:快

六大排序演算法與常見的兩大查詢演算法彙總C語言

六大排序演算法程式如下: #include<stdio.h> /*void Bubblesort(int arry[],int len)//氣泡排序演算法 { int i,j; for(i=0;i<len-1;i++) { for(j=i+1;j<le

資訊學奧賽一本通C++ 第二部分 基礎演算法 第一章 高精度計算

//1307 【例1.3】高精度乘法 //手動模擬乘法運算 //提交,測試點5,答案錯誤,猜測,應該是0的情況,沒考慮 //提供一組測試資料 //輸入: //123 //0 //輸出: //0 //考慮了0的情況,修改,提交AC 2017-11-9 //編到這裡,感覺高精度加是高精度演算法的基礎 #inc

資訊學奧賽一本通演算法C++基礎演算法:高精度計算 高精度加法(大位相加)

2018年資訊學奧賽NOIP資料下載 1 #include <bits/stdc++.h> 2 using namespace std; 3 int main() 4 { 5 char a1[100],b1[100]; 6 int a[100],b[100],c[100];/

排序演算法1:最快最簡單的排序——桶排序C++版本

下面我要開始摘抄總結了。。。。文字來源於部落格2。。。 1.什麼是桶排序 桶排序,也叫做箱排序,是一種排序演算法,也是排序演算法中最快、最簡單的排序演算法。其中的思想是我們首先要知道所有待排序的範圍,然後需要有在這個範圍的同樣數量的桶,接

資訊學奧賽一本通C++ 第二部分 基礎演算法 第四章 遞迴演算法

//1206 放蘋果 遞迴 //1192 放蘋果//http://www.cnblogs.com/dongsheng/archive/2012/08/15/2640468.html此文介紹得不錯,摘抄如下://8    解題分析://9         設f(m,n) 為m個蘋果,n個盤子的放法數目,則先對n

走進資料結構和演算法c++3——線性表的鏈式儲存結構

線性表的鏈式儲存結構   我們知道線性表的順序儲存結構在插入和刪除操作時需要移動大量的資料,他們的時間複雜度為O(n)O(n)。當我們需要經常插入和刪除資料時,順序儲存結構就不適用了,這時我們就需要用到線性表的鏈式儲存結構。   線性表的鏈式儲存結構的特點是

排序演算法之氣泡排序和快速排序Java

轉自:http://www.cnblogs.com/0201zcr/p/4763806.html  作者:Whywin 1、氣泡排序 演算法如下(排序後,由小到大排列): /** * 氣泡排序 * 比較相鄰的元素。如果第一個比第二個大,就交換他們兩個。

資訊學奧賽一本通C++ 第三部分 資料結構 第四章 圖論演算法

 資訊學奧賽一本通(C++版) 第三部分 資料結構   第四章 圖論演算法 http://ybt.ssoier.cn:8088/ 第一節 圖的遍歷 //1341 【例題】一筆畫問題 //在想,是輸出尤拉路,還是歐拉回路 //從哪點開始遍歷, //點的資料範圍,邊的資料範圍