算法導論讀書筆記(8)

算法導論讀書筆記(8)

目錄

  • 計數排序
    • 計數排序的簡單Java實現
  • 基數排序
    • 基數排序的簡單Java實現
  • 桶排序

計數排序

計數排序 假設 n 個輸入元素中的每一個都是介于0到 k 之間的整數,此處 k 為某個整數。當 k = O ( n )時,計數排序的運行時間為 Θ ( n )。

計數排序的基本思想就是對每一個輸入元素 x ,確定出小于 x 的元素個數。有了這一信息,就可以把 x 直接放到它在最終輸出數組上的位置上。

COUNTING-SORT(A, B, k)
1  let C[0 .. k] be a new array
2  for i = 0 to k
3      C[i] = 0
4  for j = 1 to A.length
5      C[A[j]] = C[A[j]] + 1
6  // C[i] now contains the number of elements equal to i.
7  for i = 1 to k
8      C[i] = C[i] + C[i - 1]
9  // C[i] now contains the number of elements less than or equal to i.
10 for j = A.length downto 1
11     B[C[A[j]]] = A[j]
12     C[A[j]] = C[A[j]] - 1

計數排序的一個重要性質是它是穩定的:具有相同值得元素在輸出數組中的相對次序與它們在輸入數組中的次序相同。而且,計數排序經常作為基數排序算法的一個子程序。

計數排序的簡單Java實現

/**
 * 計數排序
 */
public static int[] countingSort(int[] array, int k) {int[] result = new int[array.length];int[] temp = new int[k];for (int i = 0; i < k; i++)temp[i] = 0;for (int j = 0; j < array.length; j++)temp[array[j]]++;for (int i = 1; i < k; i++)temp[i] = temp[i] + temp[i - 1];for (int j = array.length - 1; j >= 0; j--) {result[temp[array[j]] - 1] = array[j];temp[array[j]]--;}return result;
}

基數排序

基數排序 要求待排序的元素擁有相同的位數。從元素的低位到高位依次排序。

RADIX-SORT(A, d)
1 for i = 1 to d
2     use a stable sort to sort array A on digit i

基數排序的簡單Java實現

public static void radixSort(int[] array) {int len = String.valueOf(array[0]).toString().length();for (int i = 0; i < len; i++)radixQuickSort(array, i);
}
/**
 * 計數排序的變形
 */
public static void radixQuickSort(int[] array, int power) {int[] result = new int[array.length];int[] temp = new int[10];for (int i = 0; i < 10; i++)temp[i] = 0;for (int j = 0; j < array.length; j++)temp[getDigit(array[j], power)]++;for (int i = 1; i < 10; i++)temp[i] = temp[i] + temp[i - 1];for (int j = array.length - 1; j >= 0; j--) {result[temp[getDigit(array[j], power)] - 1] = array[j];temp[getDigit(array[j], power)]--;}for (int i = 0; i < result.length; i++)array[i] = result[i];
}
/**
 * 獲得數字第n位的值
 */
public static int getDigit(int value, int power) {return (int) (value / Math.pow(10, power)) % 10;
}

桶排序

桶排序 (bucket sort)的輸入符合均勻分布時,它可以以線性時間運行。桶排序假設輸入由一個隨機過程產生,該過程將元素均勻地分布在區間[ 0, 1 )上。

桶排序的思想就是把區間[ 0, 1 )劃分成 n 個相同大小的子區間,或稱 。然后,將 n 個輸入數分布到各個桶中去。因為輸入數均勻分布在[ 0, 1 )上,所以,一般不會有很多數落在一個桶中的情況。為得到結果,先對各個桶中的元素進行排序,然后按次序把桶中的元素列出來即可。

BUCKET-SORT(A)
1  let B[0 .. n - 1] be a new array
2  n = A.length
3  for i = 0 to n - 1
4      make B[i] an empty list
5  for i = 1 to n
6      insert A[i] into list B[FLOOR(nA[i])]
7  for i = 0 to n - 1
8      sort list B[i] with insertion sort
9  concatenate the lists B[0], B[1], ..., B[n - 1] together in order

轉載于:https://www.cnblogs.com/sungoshawk/p/3646265.html

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

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

相關文章

Keras 深度學習框架中文文檔

2019獨角獸企業重金招聘Python工程師標準>>> Keras深度學習框架中文文檔 Keras官網&#xff1a;http://keras.io/Github項目&#xff1a;https://github.com/fchollet/keras中文文檔主頁&#xff1a;http://keras-cn.readthedocs.io/en/latest/Github中文文檔&#…

KMP算法詳解 網絡上轉的。。。仰慕此人

原網址http://www.matrix67.com/blog/archives/115 如果機房馬上要關門了&#xff0c;或者你急著要和MM約會&#xff0c;請直接跳到第六個自然段。 我們這里說的KMP不是拿來放電影的&#xff08;雖然我很喜歡這個軟件&#xff09;&#xff0c;而是一種算法。KMP算法是拿來處…

求一個二維數組外圍元素之和_C++數組作為函數的參數(學習筆記:第6章 04)...

數組作為函數的參數[1]數組元素作實參&#xff0c;與單個變量一樣。數組名作參數&#xff0c;形、實參數都應是數組名&#xff08;實質上是地址&#xff0c;關于地址詳見后續章節&#xff09;&#xff0c;類型要一樣&#xff0c;傳送的是數組首地址。對形參數組的改變會直接影響…

android p wifi一直在掃描_Android再次解讀螢石云視頻

點擊上方藍字關注 ??前言我之前寫過一篇螢石云的集成文章&#xff0c;很多人問我有沒有demo&#xff0c; 今天我再次總結一下&#xff0c; 并加個些功能。集成步驟視頻預覽播放視頻放大縮小視頻的質量切換截圖之前的文章大家可以看下面的鏈接&#xff1a;https://mp.weixin.q…

第5章 Python 數字圖像處理(DIP) - 圖像復原與重建7 - 周期噪聲 余弦噪聲生成方法

標題周期噪聲周期噪聲 周期噪聲通常是在獲取圖像期間由電氣或機電干擾產生的 def add_sin_noise(img, scale1, angle0):"""add sin noise for imageparam: img: input image, 1 channel, dtypeuint8param: scale: sin scaler, smaller than 1, will enlarge, …

python寫文字方法_Transcrypt: 用Python寫js的方法

Transcrypt是一個很有意思的工具&#xff1a; 它讓你告別手寫繁復的JavaScript代碼&#xff0c;使用相對簡明清晰的Python代替這一工作。 之后使用這個工具&#xff0c;可以把Python編寫的代碼轉換成JavaScript。 1. 為什么不直接寫JavsScript? JavaScript本身不算是很難的編程…

第5章 Python 數字圖像處理(DIP) - 圖像復原與重建8 - 估計噪聲參數

標題估計噪聲參數估計噪聲參數 周期噪聲的參數通常是通過檢測圖像的傅里葉譜來估計的。 只能使用由傳感器生成的圖像時&#xff0c;可由一小片恒定的背景灰度來估計PDF的參數。 來自圖像條帶的數據的最簡單用途是&#xff0c;計算灰度級的均值和方差。考慮由SSS表示的一個條…

python 隨機獲取數組元素_Python創建二維數組的正確姿勢

List &#xff08;列表&#xff09;是 Python 中最基本的數據結構。在用法上&#xff0c;它有點類似數組&#xff0c;因為每個列表都有一個下標&#xff0c;下標從 0 開始。因此&#xff0c;我們可以使用 list[1] 來獲取下標對應的值。如果我們深入下列表的底層原理&#xff0c…

Qt學習筆記1

1.Qt引用API時&#xff0c;QString到LPCWSTR的轉換&#xff1a; ::GetPrivateProfileIntW(QString(tr("相關設置")).utf16(),QString(tr("時間間隔")).utf16(),5,filePath.utf16())); 2.引用LPRECT時&#xff1a; RECTappRect; ::GetWindowRect(AppWnd,(LP…

在ubunut下使用pycharm和eclipse進行python遠程調試

我比較喜歡Pycharm&#xff0c;因為這個是JetBrains公司出的python IDE工具&#xff0c;該公司下的java IDE工具——IDEA&#xff0c;無論從界面還是操作上都甩eclipse幾條街&#xff0c;但項目組里有些人使用eclipse比較久了&#xff0c;一時讓他們轉pycharm比較困難&#xff…

CSS:頁腳緊貼底部

2019獨角獸企業重金招聘Python工程師標準>>> 我的練習來源于《CSS揭秘》這本書第7章-41緊貼底部的頁腳這部分內容以及書中提到的鏈接。 方案一 描述&#xff1a;以下方案簡單、干凈、現代并且沒有hack&#xff0c;適用于IE8, Chrome, Firefox, Opera等瀏覽器&#x…

第5章 Python 數字圖像處理(DIP) - 圖像復原與重建9 - 空間濾波 - 均值濾波器 - 算術平均、幾何平均、諧波平均、反諧波平均濾波器

標題只存在噪聲的復原 - 空間濾波均值濾波器算術平均濾波器幾何均值濾波器諧波平均濾波器反&#xff08;逆&#xff09;諧波平均濾波器只存在噪聲的復原 - 空間濾波 僅被加性噪聲退化 g(x,y)f(x,y)η(x,y)(5.21)g(x, y) f(x, y) \eta(x, y) \tag{5.21}g(x,y)f(x,y)η(x,y)(5…

librosa能量_librosa與python_speech_features

在語音識別領域&#xff0c;比較常用的兩個模塊就是librosa和python_speech_features了。最近也是在做音樂方向的項目&#xff0c;借此做一下筆記&#xff0c;并記錄一些兩者的差別。下面是兩模塊的官方文檔LibROSA - librosa 0.6.3 documentation?librosa.github.ioWelcome t…

java Unicode轉碼

1 //中文轉UNICODE2 public static String chinaToUnicode(String str) {3 String result "";4 for (int i 0; i < str.length(); i) {5 int chr1 (char) str.charAt(i);6 if (chr1 > 19968 && ch…

oracle-備份工具exp-imp

雖然是按照用戶的方式導出的&#xff0c;但導入之前&#xff0c;還是必須要有相同的用戶存在&#xff0c;刪除用戶以后&#xff0c;是無法進行導入的 --重新創建回zlm用戶 SQL> create user zlm identified by zlm; 盡管zlm用戶的默認表空間是USERS&#xff0c;但是用imp導入…

繼承String?

不能繼承&#xff0c;因為 public final class String extends Objectimplements Serializable, Comparable<String>, CharSequence final修飾的類是不能被繼承的轉載于:https://www.cnblogs.com/crane-practice/p/3666006.html

python中字典數據的特點_Python數據類型(字典)

Python 字典(Dictionary) 字典是另一種可變容器模型&#xff0c;且可存儲任意類型對象。 字典的每個鍵值(key>value)對用冒號(:)分割&#xff0c;每個對之間用逗號(,)分割&#xff0c;整個字典包括在花括號({})中 ,格式如下所示&#xff1a; d {key1: value1, key2: value2}…

第5章 Python 數字圖像處理(DIP) - 圖像復原與重建10 - 空間濾波 - 統計排序濾波器 - 中值、最大值、最小值、中點、修正阿爾法均值濾波器

標題統計排序濾波器中值、最大值、最小值、中點 濾波器修正阿爾法均值濾波器統計排序濾波器 中值、最大值、最小值、中點 濾波器 f^(x,y)median{g(r,c)}(5.27)\hat{f}(x, y) \text{median} \{g(r,c)\} \tag{5.27}f^?(x,y)median{g(r,c)}(5.27) f^(x,y))max{g(r,c)}(5.28)\ha…

如何設置坐標原點值_氨氣檢測儀電化學原理及報警值如何設置

氨氣體檢測儀檢定規程&#xff1a;一般氨氣體檢測儀檢定規程主要是針對技術參數設定的一些標準&#xff0c;具體包含有規程的名稱和范圍、儀器示值誤差、充分性標準差、響應時間、穩定性、報警功能、流量控制器、檢定項目表、檢定操作有數值誤差、重復性、響應時間、穩定性等。…

統計信息及相關說明

統計信息&#xff1a;0 recursive calls20434 db block gets 317970511 consistent gets 0 physical reads 3759764 redo size 382 bytes sent via SQL*Net to client 1061 bytes received via SQL*Net from client 3 SQL*Ne…