歸并排序與逆序對

在刷題的過程中碰到了關于無序序列的逆序對統計的問題。

直接暴力會超時,然后搜索了一下算法,發現可以通過歸并排序的思想來做到這個統計的過程。看代碼的時候,不知道自己的理解力不夠還是不熟悉別人的代碼,反正是看不懂。無奈之下自己按照自己的理解實現了一下這個算法,順便復習了一下歸并排序算法,所以有了這么一篇文章。算是個筆記吧。

思想很簡單:

  1. 數組分成左右兩部分
  2. 兩個子數組排序
  3. 兩個數組合并,這個合并的過程中,如果左邊的key值大于右邊的key值,就產生了逆序對。因為左邊數組是有序的,所以,這個時候產生的逆序對的個數是剩余未處理的部分的長度,將這個數值統計起來就是我們要的結果。
  4. 算法復雜度為$nlog_2 n$
class MergeSort
{public int sort(int[] array, int p, int r){if (p < r){int q = p + (r - p) / 2;int len1 = sort(array, p, q);      //子數組排序int len2 = sort(array, q + 1, r);int count = merge(array, p, q, r);return len1 + len2 + count;}else{return 0;}}public int merge(int[] array, int p, int q, int r){int n1 = q - p + 1;int n2 = r - q;int[] array1 = new int[n1 + 1];int[] array2 = new int[n2 + 1];array1[n1] = int.MaxValue;array2[n2] = int.MaxValue;for (int i = 0; i < n1; i++){array1[i] = array[p + i];}for (int i = 0; i < n2; i++){array2[i] = array[q + 1 + i];}int index1 = 0, index2 = 0;int count = 0;for (int i = p; i <= r; i++){if (array1[index1] <= array2[index2]){array[i] = array1[index1++];}else{array[i] = array2[index2++];count += n1 - index1;//數組有序,所以剩下幾個key就有一個key比array2[index2]大也就是有幾個逆序對。}}return count;}
}

算法的有效性:

  1. 因為合并前,左右數組有序
  2. 左邊的key值如果大于右邊的key值,就代表有逆序對產生。因為數組有序,這樣左邊剩余的key值肯定更大,所以剩余幾個key就有幾個逆序對。
  3. 算法的整個過程是遞歸實現的,比較小的key值是一點一點移動到前面來消除逆序對,這個過程是沒有逆向的。

轉載于:https://www.cnblogs.com/36hours/p/6606960.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/396409.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/396409.shtml
英文地址,請注明出處:http://en.pswp.cn/news/396409.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c#獲取pdf文件頁數

引用命名空間&#xff1a;using iTextSharp.text.pdf; string filePath Server.MapPath("/upload/123.pdf"); //文件的物理路徑PdfReader reader new PdfReader(filePath);int iPageNum reader.NumberOfPages; //文件頁數reader.Close();Response.Write("文件…

VS2015 Cordova Ionic移動開發(五)

一、創建側邊菜單和導航項目 1.使用VS創建一個Ionic空項目&#xff0c;同時創建一個Ionic SideMenu和Ionic Tabs項目。將SideMenu和Tabs項目里的templates和js文件合并到空項目里&#xff0c;修改js對應的代碼即可。完整項目工程如下&#xff1a; 2.App.js代碼修改如下&#xf…

最佳適應算法和最壞適應算法_算法:好,壞和丑陋

最佳適應算法和最壞適應算法by Evaristo Caraballo通過Evaristo Caraballo 算法&#xff1a;好&#xff0c;壞和丑陋 (Algorithms: The Good, The Bad and The Ugly) Who has been in Free Code Camp without having the experience of spending hours trying to solve Algori…

mysql條件觸發器實例_mysql觸發器實例一則

例子&#xff0c;實例學習mysql觸發器的用法。一&#xff0c;準備二張測試表&#xff1a;1&#xff0c;測試表1復制代碼 代碼示例:DROP TABLE IF EXISTS test;CREATE TABLE test (id bigint(11) unsigned NOT NULL AUTO_INCREMENT,name varchar(100) NOT NUL…

阿里大數據神預測 勝率僅5.9%中國卻1:0勝韓國

寫在最前面&#xff1a;這是早晨偶然看到的一篇文章&#xff0c;是對昨天中國卻1&#xff1a;0勝韓國的評論。有朋友感慨&#xff1a;努力不放棄的時候&#xff0c;全世界都會幫你。這篇內容很全面的串起阿里巴巴在大數據預測方面的動作&#xff0c;角度很別致&#xff0c;分享…

Python中類、對象與self詳解

先介紹一下python中的類與對象/實例。然后詳細說明self。說明&#xff1a;對象等同實例&#xff0c;本文稱呼不一致時請自行統一 【一】類與對象/實例 1、類 &#xff08;1&#xff09;類由名稱、屬性、方法三部分組成 &#xff08;2&#xff09;類是抽象模板&#xff0c;比如學…

面試題28 字符串排列

題目描述 輸入一個字符串,按字典序打印出該字符串中字符的所有排列。例如輸入字符串abc,則打印出由字符a,b,c所能排列出來的所有字符串abc,acb,bac,bca,cab和cba。 結果請按字母順序輸出。 輸入描述: 輸入一個字符串,長度不超過9(可能有字符重復),字符只包括大小寫字母。 1 cla…

javascript 框架_克服JavaScript框架疲勞

javascript 框架by Tero Parviainen通過Tero Parviainen 克服JavaScript框架疲勞 (Overcoming JavaScript Framework Fatigue) The JavaScript community is suffering from a wave of framework fatigue. It’s caused by the massive outpouring of new frameworks, techniq…

java開發環境:還在配classpath?你out啦!

2019獨角獸企業重金招聘Python工程師標準>>> 先說結論&#xff1a;只需要配置JAVA_HOME和path路徑即可&#xff0c;無需配置classpath 參考Oracle官網的說明&#xff1a; The class path tells JDK tools and applications where to find third-party and user-defi…

qpython3可以調用哪些庫_Python3 如何使用asyncio庫在調用第三方模塊(存在IO等待)的情況下實現協程?...

問題描述demo中有一個 task_check 的模塊,底層是用urllib實現,請問如果要實現使用 asyncio 庫實現協程操作,需要修改這個模塊的底層代碼嗎?如何修改? 往大佬指點問題出現的環境背景及自己嘗試過哪些方法平時都是使用 gevent 庫和 monkey.patch_all() 實現協程,但發現 gevent …

.Net Core 商城微服務項目系列(二):使用Ocelot + Consul構建具備服務注冊和發現功能的網關...

1.服務注冊 在上一篇的鑒權和登錄服務中分別通過NuGet引用Consul這個包&#xff0c;同時新增AppBuilderExtensions類&#xff1a; public static class AppBuilderExtensions{public static IApplicationBuilder RegisterConsul(this IApplicationBuilder app,IApplicationLife…

java打印數組_Java中打印數組內容的方式有哪些?

下面是幾種常見的打印方式。方法一&#xff1a;使用循環打印。public class Demo {public static void main(String[] args) {String[] infos new String[] {"Java", "Android", "C/C", "Kotlin"};StringBuffer strBuffer new Strin…

$(function() {})

$(function() {});是$(document).ready(function(){ })的簡寫&#xff0c; 最早接觸的時候也說$(document).ready(function(){ })這個函數是用來取代頁面中的window.onload; 用來在DOM加載完成之后執行一系列預先定義好的函數。

恢復工具

EasyRecovery http://www.upantool.com/hfxf/huifu/2011/EasyRecovery_V6.22.html轉載于:https://www.cnblogs.com/cb168/p/5359133.html

四參數坐標轉換c++_GPSRTK坐標轉換及四參數、七參數適用條件

工程測量儀器已由經緯儀、全站儀過渡到GNSS(全球衛星導航系統)&#xff0c;特別是公路行業&#xff0c;GPS-RTK作為GNSS的一種應用目前已十分普及。現階段GPS-RTK以WGS-84 坐標系統為主流&#xff0c;所發布的星歷參數也是基于此坐標系統&#xff0c;但隨著北斗導航系統的逐步完…

教主的魔法

傳送門 這道題序列很長&#xff0c;但是操作數很少&#xff0c;然后也沒想到什么好的數據結構來維護&#xff0c;那就分塊吧。 感覺維護的過程很好想&#xff0c;修改的時候對于整個塊都在內的直接打標記&#xff0c;兩個零散的區間暴力重構&#xff0c;重新排序。查詢的時候&a…

obs自定義編碼設置_通過7個步驟設置OBS進行實時編碼

obs自定義編碼設置by Wesley McCann韋斯利麥肯(Wesley McCann) 通過7個步驟設置OBS進行實時編碼 (Setting up OBS for Live Coding in 7 Steps) Twitch TV is a popular live-streaming service. You traditionally used Twitch to stream yourself playing video games, but …

java hadoop api_Hadoop 系列HDFS的Java API( Java API介紹)

HDFS的Java APIJava API介紹將詳細介紹HDFS Java API&#xff0c;一下節再演示更多應用。Java API 官網如上圖所示&#xff0c;Java API頁面分為了三部分&#xff0c;左上角是包(Packages)窗口&#xff0c;左下角是所有類(All Classes是)窗口&#xff0c;右側是詳情窗口。這里推…

最大連通子數組

這次是求聯通子數組的求和&#xff0c;我們想用圖的某些算法&#xff0c;比如迪杰斯特拉等&#xff0c;但是遇到了困難。用BFS搜索能達到要求&#xff0c;但是還未能成功。 那么我們這樣想&#xff0c;先將每行的最大子數組之和&#xff0c;然后再將這些最大之和組成一個數組&a…

redis的zset的底層實現_Redis(三)--- Redis的五大數據類型的底層實現

1、簡介Redis的五大數據類型也稱五大數據對象&#xff1b;前面介紹過6大數據結構&#xff0c;Redis并沒有直接使用這些結構來實現鍵值對數據庫&#xff0c;而是使用這些結構構建了一個對象系統redisObject&#xff1b;這個對象系統包含了五大數據對象&#xff0c;字符串對象(st…