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

拜托,面試別再問我最大值最小值了!!!

開發(fā) 開發(fā)工具
如何從n個(gè)數(shù)里找到最大值與最小值?很容易想到,用一個(gè)循環(huán)找到最大值和最小值,就能搞定。那么,還有沒有更快的方法呢?

如何從n個(gè)數(shù)里找到***值?

很容易想到,用一個(gè)循環(huán)就能搞定。

  1. int find_max(int arr[n]){ 
  2.     int max = -infinite; 
  3.     for(int i=0; i<n; i++) 
  4.         if(arr[i]>max) 
  5.             max=arr[i]; 
  6.     return max; 
  7.   

這里,需要執(zhí)行n-1次比較。

[[255078]]

如何從n個(gè)數(shù)里找到***值與最小值?

很容易想到,用一個(gè)循環(huán)找到***值和最小值,就能搞定。

  1. (int, int) find_max_min(int arr[n]){ 
  2.     int max = -infinite; 
  3.     int min = infinite
  4.   
  5.     for(int i=0; i<n; i++){ 
  6.         if(arr[i]>max) 
  7.             max=arr[i]; 
  8.         if(arr[i]<min
  9.             min=arr[i]; 
  10.     } 
  11.   
  12.     return (max, min); 

這里,需要執(zhí)行2*(n-1)=2n-2次比較。

還有沒有更快的方法呢?

分治法或許可以派上用場(chǎng),分治法的思路是:

  • 把大規(guī)模拆分成小規(guī)模;
  • 小規(guī)模分別求解;
  • 小規(guī)模求解之后,再綜合求解大規(guī)模;

看能不能往這個(gè)例子里套用:

  • 將arr[0,n]分為arr[0,n/2]和arr[n/2,n];
  • 每個(gè)子數(shù)組分別求解***值和最小值;
  • 兩個(gè)子數(shù)組的***值里再取***值,兩個(gè)子數(shù)組的最小值里再取最小值,就是最終解;

偽代碼大概是這樣:

  1. (int, int) find_max_min(int arr[0,n]){ 
  2.     // 遞歸左半?yún)^(qū) 
  3.     (max1, min1) = find_max_min(arr[0, n/2]); 
  4.     // 遞歸右半?yún)^(qū) 
  5.     (max2, min2) = find_max_min(arr[n/2, n]); 
  6.   
  7.     // 再計(jì)算兩次 
  8.     max = max1>max2?max1:max2; 
  9.     min = min1<min2?min1:min2; 
  10.   
  11.     return (max, min); 

畫外音,實(shí)際的遞歸代碼要注意:

  • 入?yún)⒉皇?和n,而是數(shù)組的下限和上限;
  • 遞歸要收斂,當(dāng)數(shù)組的上下限相差1時(shí),只比較一次,直接返回max和min,而不用再次遞歸;

分治法之后,時(shí)間復(fù)雜度是多少呢?

如果你是“架構(gòu)師之路”的老讀者,《搞定所有時(shí)間復(fù)雜度計(jì)算》一文,能夠輕松求解分治法的時(shí)間復(fù)雜度分析:

(1)當(dāng)只有2個(gè)元素時(shí),只需要1次計(jì)算就能知道***,最小值

(2)當(dāng)有n個(gè)元素時(shí),

  • 遞歸左半?yún)^(qū);
  • 遞歸右半?yún)^(qū);
  • 再進(jìn)行兩次計(jì)算;
    1. f(2)=1;【式子A】 
    2. f(n)=2*f(n/2)+2;【式子B】 

求解遞歸式子,得到:

  1. f(n)=1.5n-2; 

畫外音,證明過程如下:

【式子B】不斷展開能得到:

  1. f(n)=2*f(n/2)+2;【式子1】 
  2. f(n/2)=2*f(n/4)+2;【式子2】 
  3. f(n/4)=2*f(n/8)+2;【式子3】 
  4. ... 
  5. f(n/2^(m-1))=2*f(2^m)+2;【式子m】 

通過這m個(gè)式子的不斷代入,得到:

  1. f(n)=(2^m)*f(n/2^m)+2^(m+1)-2;【式子C】 
  2.   
  3. 由于f(2)=1【式子A】; 
  4. 即【式子C】中n/2^m=2時(shí),f(n/2^m)=f(2)=1; 
  5. 此時(shí)n=2^(m+1),代入【式子C】 
  6. 即f(n)=n/2 + n -2 = 1.5n-2; 

證明過程很嚴(yán)謹(jǐn),但我知道你沒看懂。

建議再看看《搞定所有時(shí)間復(fù)雜度計(jì)算》。

總結(jié),n個(gè)數(shù):

  • 求***值,遍歷,需要n-1次計(jì)算
  • 求***最小值,遍歷,需要2n-2次計(jì)算
  • 求***最小值,分治,時(shí)間復(fù)雜度1.5n-2

思路比結(jié)論重要,希望大家有收獲。

【本文為51CTO專欄作者“58沈劍”原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】

戳這里,看該作者更多好文

責(zé)任編輯:趙寧寧 來源: 51CTO專欄
相關(guān)推薦

2019-04-16 13:30:05

表達(dá)式求值數(shù)據(jù)結(jié)構(gòu)算法

2018-09-28 05:25:53

TopK算法代碼

2018-11-01 13:49:23

桶排序排序面試

2018-10-28 22:37:00

計(jì)數(shù)排序排序面試

2018-11-06 11:40:19

時(shí)間復(fù)雜度面試算法

2020-04-22 11:19:07

貪心算法動(dòng)態(tài)規(guī)劃

2021-01-22 10:09:23

簡歷求職者面試

2020-03-30 17:20:54

B+樹SQL索引

2020-09-02 08:04:59

多線程互聯(lián)網(wǎng)高并發(fā)

2022-03-14 10:14:43

底層系統(tǒng)Nacos

2018-11-09 09:34:05

面試Spring Clou底層

2010-09-26 15:56:59

SQL查詢

2020-04-16 08:22:11

HTTPS加解密協(xié)議

2020-12-11 09:24:19

Elasticsear存儲(chǔ)數(shù)據(jù)

2010-11-24 16:42:40

mysql命令行求最小

2020-09-24 14:40:55

Python 開發(fā)編程語言

2019-08-29 09:49:50

2009-09-17 09:50:34

數(shù)組

2021-05-09 22:41:43

Python數(shù)據(jù)統(tǒng)計(jì)

2015-02-13 10:42:31

前端工具Dreamweaver
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产精品久久久久久吹潮 | 久久久久国产精品午夜一区 | 91原创视频 | 国产欧美日韩精品一区二区三区 | 国产精品久久久久久中文字 | www亚洲免费国内精品 | 美女在线视频一区二区三区 | www.成人.com| 国产高清在线精品一区二区三区 | 毛片在线免费 | 毛片久久久 | 色婷婷国产精品综合在线观看 | 成人看片在线观看 | 日本午夜精品一区二区三区 | 日日夜夜天天 | 国产毛片久久久 | 91麻豆精品国产91久久久久久 | 奇米av| 亚洲久草 | 国产在线对白 | 久久精品天堂 | 亚洲免费网站 | 亚洲一级二级三级 | 国产高清免费 | 九九热视频这里只有精品 | 91在线精品视频 | www.黄网 | 精品一区二区三区中文字幕 | av黄色片| 亚洲美女网站 | 久久国产亚洲精品 | 成人精品一区二区三区中文字幕 | 亚洲日本欧美 | 免费中文字幕 | 欧美黄色大片在线观看 | 欧美视频精品 | 欧美一区二区在线观看 | 免费国产一区 | 中文字幕日韩一区二区 | 久久久久国产精品一区二区 | 国产精品一区二区在线观看 |