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

輕松掌握編程基本算法(二)

移動開發 算法
筆者贊同他們建議在學校里將計算機基礎打好,沒有良好基礎怎么能建大廈呢?有了一些基礎基本知識,在去學習深的理論 就是事半功倍了,如果是先遇到深理論在去學習相關的基礎,那就是事倍功半了。

[[121970]]

在寫此文章之前,筆者想說說關于程序員的基本知識,好多人在談論自己的工作經歷,或者給畢業生的建議,筆者贊同他們建議同學在學校里將計算機基礎打好,沒有良好基礎怎么能建大廈呢?有了一些基礎基本知識,在去學習深的理論 就是事半功倍了,如果是先遇到深理論在去學習相關的基礎,那就是事倍功半了。也許許多同學會說,現在的很多企業都招能直接上手的,筆者首先想說那種企業肯定是小企業,鼠目寸光,招也找不到很優秀的人才,就算去了,這種人才也不會呆很長時間,因為這種企業沒有發展的遠見,有技術的人才可能因沒發展前途而跳槽。其次筆者想說如果你有良好的計算機基礎,筆者相信你能成功在三個月之內學習適應達到企業技術要求。

其實,筆者想表達任何時候不要忽略基礎。閑話不多說了,直接轉基本排序算法。

編程基本算法(一)

編程基本算法(二)

編程基本算法(三) 

冒泡排序

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

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

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

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

性能分析:時間復雜度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. //希爾排序自增量需要自己合適選擇 
  2. void ShellSort(int b[10]) 
  3. int h,i; 
  4. int n=10; 
  5. //通過這個循環算出增量為1和4 
  6. for(h=1;h<=n/9;h=3*h+1); 
  7.  
  8. //增量循環 
  9. for(;h>0;h/=3) 
  10. for(i=h;i<n;i++) 
  11. int j,temp; 
  12. temp=b[i]; 
  13. //插入排序 
  14. for(j=i-h;j>=0;j=j-h) 
  15. if(b[j]>temp) 
  16. b[j+h]=b[j]; 
  17. else 
  18. break
  19. b[j+h]=temp; 
  20. cout<<"the sort is:"
  21. for(int i=0;i<10;i++) 
  22. cout<<b[i]<<" "
  23. cout<<endl; 

性能分析:時間復雜度對于希爾排序就有點復雜,它根據具體的“增量”不同而不同,這里筆者采用嚴蔚敏《數據結構》的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. void Sawp(int *a,int *b); 
  5. int Old_low=low; 
  6. int Old_high=high; 
  7. while(low<high) 
  8. while(*(b+high)>=*(b+low)&&low<high)high--; 
  9. Sawp(b+low,b+high); 
  10. while(*(b+low)=<*(b+high)&&low<high)low++; 
  11. Sawp(b+low,b+high); 
  12. if(Old_low<low-1) 
  13. QuickSort(b,Old_low,low-1); 
  14. if(high+1<Old_high) 
  15. QuickSort(b,high+1,Old_high); 
  16.  
  17. //交換函數 
  18. void Sawp(int *a,int *b) 
  19. int temp; 
  20. temp=*a; 
  21. *a=*b; 
  22. *b=temp; 

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

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

責任編輯:閆佳明 來源: cnblogs
相關推薦

2014-10-30 16:12:55

編程技術算法

2014-10-30 16:41:14

編程技術算法

2023-07-06 08:31:50

Python對象編程

2023-12-11 18:18:24

Python編程線程

2024-04-10 08:59:39

SpringAOP業務

2022-11-06 21:50:59

Python編程函數定義

2010-01-06 17:51:26

Linux關機命令

2023-08-04 09:43:16

Socket編程Python

2009-10-12 13:18:55

RHEL 4內核

2023-09-13 08:00:00

MLOps數據科學

2012-07-17 10:54:49

AJAX

2009-12-16 14:26:19

Linux VMwar

2010-01-04 17:35:32

Silverlight

2009-11-12 10:32:47

ADO.NET技術

2009-01-18 15:14:00

數據倉庫開發OLTP

2023-05-10 07:42:26

Java多線程編程

2009-11-09 15:28:04

WCF知識結構

2009-11-17 17:38:37

PHP Session

2009-12-14 11:15:34

Linux chgrp

2024-02-27 08:22:56

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美精品久久久 | 精品国产乱码久久久久久88av | 91夜夜夜| 成人性视频免费网站 | 亚洲精品91 | 特一级黄色毛片 | 亚洲 中文 欧美 日韩 在线观看 | 九九一级片 | 99精品在线观看 | 一级黄色夫妻生活 | 久久不射网 | 伊人久麻豆社区 | 欧美久久一区 | 国产乱码精品一区二区三区中文 | 成人免费一区二区 | 99re视频在线 | 欧美日韩中文字幕在线 | 精品视频一区二区三区在线观看 | 国产精品久久久久久亚洲调教 | 在线观看日本高清二区 | 欧美视频三区 | 国产在线精品一区二区 | 人人操日日干 | 一级片视频免费 | 欧美 日韩 国产 一区 | 久久国内 | 成人免费一级 | 蜜桃av一区二区三区 | 男女网站在线观看 | 一区二区三区精品视频 | 91精品国产综合久久福利软件 | 91啪影院| 免费亚洲网站 | 毛片毛片毛片毛片毛片 | 爽爽免费视频 | 99久久精品一区二区毛片吞精 | 国内精品伊人久久久久网站 | 欧美极品在线 | 国产一区二区精品 | 一区影院 | 在线播放国产一区二区三区 |