成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

數據庫入門級之算法【二】

數據庫 算法
上一篇《數據庫入門級之算法【一】》與大家分享了部分數據算法,今次小編繼續與大家分享其他的數據算法。

上一篇《數據庫入門級之算法【一】》中我們介紹了一些數據算法,現在我們繼續介紹一些基本排序算法。

冒泡排序

使用條件:集合的元素可對比大小

算法思想:連續地掃描待排序的記錄,每掃描一次,都會找出最小記錄,使之更接近頂部。由于每次掃描都會把一條記錄置于它的最終最正確的位置,因此下次掃描不需要重新檢查這條記錄

舉例編程:int b[10]={77,1,65,13,81,93,10,5,23,17}將其冒泡排序(這里筆者將概念弄混淆了,感謝zdd的指出)

  1. //冒泡排序  
  2. void Bubble(int b[10])  
  3. {  
  4.     int temp;  
  5.     int i;  
  6.     for(i=9;i>0;i--)  
  7.     {  
  8.         for(int j=0;j
  9.         {  
  10.             if(b[j]>b[j+1])  
  11.             {  
  12.                 temp=b[j];  
  13.                 b[j]=b[j+1];  
  14.                 b[j+1]=temp;  
  15.             }  
  16.         }  
  17.     }  
  18.     cout<<"the sort is:";  
  19.     for(int i=0;i<10;i++)  
  20.     {  
  21.         cout<" ";  
  22.     }  
  23.     cout<
  24. }  

性能分析:時間復雜度O(n^2)

希爾排序

使用條件:集合的元素可對比大小

算法思想:先將整個待排記錄序列分割成為若干子序列分別進行直接插入排序,待整個序列中的記錄“基本有序“時,在對全體記錄進行一次直接插入排序。子序列構成的不是簡單“逐段分割”,而是相隔某個“增量”的記錄組成一個子序列。因此比較排序時候關鍵字較小的記錄就不是一步一步往前挪動,而是相隔一定增量移動,該“增量”呈現一個遞減趨勢,最后這個“增量”總是為1,那么此時序列已基本有序,只要作少量的比較和移動幾個完成排序。希爾排序不好把握增量的設定。一般8個數我們認為設定“增量”為:4,2,1。(這是一般希爾排序的設定)。那么筆者這里要擬定一個求“增量”的公式 h(n+1)=3*h(n)+1,(h>N/9停止)這個公式可能選擇增量不是最合適,但是卻適用一般“增量”的設定。如果是8個數的話,那么這里增量就是1。

舉例編程:int b[10]={77,1,65,13,81,93,10,5,23,17}將其希爾排序

//希爾排序自增量需要自己合適選擇

  1. void ShellSort(int b[10])  
  2. {  
  3.    int h,i;  
  4.    int n=10;  
  5.    //通過這個循環算出增量為1和4  
  6.    for(h=1;h<=n/9;h=3*h+1);  
  7.       //增量循環  
  8.    for(;h>0;h/=3)  
  9.    {  
  10.       for(i=h;i
  11.       {  
  12.          int j,temp;  
  13.          temp=b[i];  
  14.          //插入排序  
  15.          for(j=i-h;j>=0;j=j-h)  
  16.          {  
  17.             if(b[j]>temp)  
  18.             {  
  19.                 b[j+h]=b[j];  
  20.             }  
  21.             else 
  22.             {  
  23.                 break;  
  24.             }  
  25.          }  
  26.          b[j+h]=temp;  
  27.       }  
  28.    }  
  29.    cout<<"the sort is:";  
  30.    for(int i=0;i<10;i++)  
  31.    {   
  32.          cout<" ";  
  33.    }  
  34.    cout<
  35. }  

性能分析:時間復雜度對于希爾排序就有點復雜,它根據具體的“增量”不同而不同,這里筆者采用嚴蔚敏《數據結構》的O(n^3/2)

快速排序

使用條件:可對比大小的集合。

算法思想:通過一趟排序將待排序記錄分割成獨立的兩部分,其中一部分記錄的關鍵字均比另一部分關鍵字小,則可分別對這兩部分記錄繼續這種排序,最后達到有序序列。這里有一個關鍵點,就是選取分割的“基準”。肯定是大于這個“基準”分成一個部分,小于這個“基準”分成一個部分。這里筆者默認取該部分第一個記錄為“基準”。

舉例編程:int b[10]={77,1,65,13,81,93,10,5,23,17}

  1. //快速排序  
  2. void QuickSort(int *b,int low,int high)  
  3. {  
  4.     //交換函數  
  5.     void Sawp(int *a,int *b);  
  6.     int Old_low=low;  
  7.     int Old_high=high;  
  8.     while(low
  9.     {  
  10.         while(*(b+high)>*(b+low)&&low--;  
  11.         Sawp(b+low,b+high);  
  12.         while(*(b+low)<*(b+high)&&low
  13.         Sawp(b+low,b+high);  
  14.     }  
  15.     if(Old_low
  16.     {  
  17.         QuickSort(b,Old_low,low-1);  
  18.     }  
  19.     if(high+1
  20.     {  
  21.         QuickSort(b,high+1,Old_high);  
  22.     }  
  23. }  
  24. //交換函數  
  25. void Sawp(int *a,int *b)  
  26. {  
  27.     int temp;  
  28.     temp=*a;  
  29.     *a=*b;  
  30.     *b=temp;  
  31. }  

性能分析:時間復雜度O(nlogn)

到這個,我們介紹了我們常見的基本數據查找和排序的算法,而這些是最基礎的算法,很多算法可以由他們延伸。

原文鏈接:http://www.cnblogs.com/couhujia/archive/2011/03/24/1993373.html

【編輯推薦】

  1. 初探數據挖掘中的十大經典算法
  2. 當今世界最受人們重視的十大經典算法
  3. 程序員須知之面試時算法題的解答思路
  4. 數據庫入門級之算法【一】
責任編輯:艾婧 來源: 博客園
相關推薦

2011-03-25 09:09:29

算法數據庫

2011-03-25 11:01:33

算法數據庫

2013-05-06 09:14:26

BigQuery大數據分析大數據分析入門

2023-04-14 15:02:55

機器學習算法

2015-11-13 10:06:27

數據科學大數據入門

2021-02-08 12:59:12

Git 控制系統

2010-06-23 10:55:10

FreeBSD入門級命

2010-09-13 13:58:17

HTML DOM

2010-09-08 12:45:16

2016-01-08 13:41:48

戴爾

2025-04-15 10:20:00

FastAPI角色權限系統RBAC

2011-08-11 22:09:46

激光打印機推薦

2009-06-30 14:59:36

連接數據庫JSP入門

2018-07-24 09:38:35

JavaMySQLJDBC

2015-07-13 11:20:01

iPhone內存蘋果

2016-03-28 09:54:27

ios開發入門

2017-04-07 10:49:54

NVIDIA入門GTX 1030

2017-05-10 09:26:41

機器學習深度學習

2017-07-21 17:19:45

戴爾

2011-05-10 14:53:27

專業顯卡評測
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久免费视频在线 | 91麻豆久久久 | 欧美成人h版在线观看 | 国产成人99久久亚洲综合精品 | 婷婷免费视频 | 日韩av在线免费 | 国产日韩精品久久 | 成人欧美一区二区三区黑人孕妇 | 男人天堂网址 | 国产视频综合 | 久久国产一区 | 日韩成人一区 | 国产一区二区小视频 | 日韩精品在线网站 | 中文字幕亚洲视频 | 国内精品一区二区三区 | 91免费在线看 | 毛片a级 | 天天干天天操天天看 | 日韩a在线 | 色综合久久88色综合天天 | 特黄毛片视频 | 亚洲精品一区二区三区 | 久久精品久久综合 | 国产成人精品一区二 | 成人在线免费网站 | 日韩一区二区三区视频在线观看 | 精精国产xxxx视频在线播放 | 久久99深爱久久99精品 | 久久久久国产一区二区三区 | 黄色免费av| 最新日韩欧美 | 黄色香蕉视频在线观看 | 日韩不卡在线 | av三级| 久久天天躁狠狠躁夜夜躁2014 | 日韩成人影院 | 男人午夜视频 | 成年人免费看 | 69热视频在线观看 | 99精品免费久久久久久日本 |