在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何求遞歸算法的時間復雜度

算法與數據結構 ? 來源:代碼隨想錄 ? 作者:代碼隨想錄 ? 2022-07-13 11:33 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本篇通過一道面試題,一個面試場景,來好好分析一下如何求遞歸算法的時間復雜度。

相信很多同學對遞歸算法的時間復雜度都很模糊,那么這篇Carl來給大家通透的講一講。

同一道題目,同樣使用遞歸算法,有的同學會寫出了O(n)的代碼,有的同學就寫出了O(logn)的代碼。

這是為什么呢?

如果對遞歸的時間復雜度理解的不夠深入的話,就會這樣!

那么我通過一道簡單的面試題,模擬面試的場景,來帶大家逐步分析遞歸算法的時間復雜度,最后找出最優解,來看看同樣是遞歸,怎么就寫成了O(n)的代碼。

面試題:求x的n次方

想一下這么簡單的一道題目,代碼應該如何寫呢。最直觀的方式應該就是,一個for循環求出結果,代碼如下:

intfunction1(intx,intn){
intresult=1;//注意任何數的0次方等于1
for(inti=0;i

時間復雜度為O(n),此時面試官會說,有沒有效率更好的算法呢。

如果此時沒有思路,不要說:我不會,我不知道了等等。

可以和面試官探討一下,詢問:“可不可以給點提示”。面試官提示:“考慮一下遞歸算法”。

那么就可以寫出了如下這樣的一個遞歸的算法,使用遞歸解決了這個問題。

intfunction2(intx,intn){
if(n==0){
return1;//return1同樣是因為0次方是等于1的
}
returnfunction2(x,n-1)*x;
}

面試官問:“那么這個代碼的時間復雜度是多少?”。

一些同學可能一看到遞歸就想到了O(logn),其實并不是這樣,遞歸算法的時間復雜度本質上是要看:遞歸的次數 * 每次遞歸中的操作次數。

那再來看代碼,這里遞歸了幾次呢?

每次n-1,遞歸了n次時間復雜度是O(n),每次進行了一個乘法操作,乘法操作的時間復雜度一個常數項O(1),所以這份代碼的時間復雜度是 n * 1 = O(n)。

這個時間復雜度就沒有達到面試官的預期。于是又寫出了如下的遞歸算法的代碼:

intfunction3(intx,intn){
if(n==0){
return1;
}
if(n%2==1){
returnfunction3(x,n/2)*function3(x,n/2)*x;
}
returnfunction3(x,n/2)*function3(x,n/2);
}

面試官看到后微微一笑,問:“這份代碼的時間復雜度又是多少呢?” 此刻有些同學可能要陷入了沉思了。

我們來分析一下,首先看遞歸了多少次呢,可以把遞歸抽象出一顆滿二叉樹。剛剛同學寫的這個算法,可以用一顆滿二叉樹來表示(為了方便表示,選擇n為偶數16),如圖:

fc74a264-025a-11ed-ba43-dac502259ad0.png

當前這顆二叉樹就是求x的n次方,n為16的情況,n為16的時候,進行了多少次乘法運算呢?

這棵樹上每一個節點就代表著一次遞歸并進行了一次相乘操作,所以進行了多少次遞歸的話,就是看這棵樹上有多少個節點。

熟悉二叉樹話應該知道如何求滿二叉樹節點數量,這顆滿二叉樹的節點數量就是2^3 + 2^2 + 2^1 + 2^0 = 15,可以發現:這其實是等比數列的求和公式,這個結論在二叉樹相關的面試題里也經常出現。

這么如果是求x的n次方,這個遞歸樹有多少個節點呢,如下圖所示:(m為深度,從0開始)

fc93b21c-025a-11ed-ba43-dac502259ad0.png

時間復雜度忽略掉常數項-1之后,這個遞歸算法的時間復雜度依然是O(n)。對,你沒看錯,依然是O(n)的時間復雜度!

此時面試官就會說:“這個遞歸的算法依然還是O(n)啊”, 很明顯沒有達到面試官的預期。

那么O(logn)的遞歸算法應該怎么寫呢?

想一想剛剛給出的那份遞歸算法的代碼,是不是有哪里比較冗余呢,其實有重復計算的部分。

于是又寫出如下遞歸算法的代碼:

intfunction4(intx,intn){
if(n==0){
return1;
}
intt=function4(x,n/2);//這里相對于function3,是把這個遞歸操作抽取出來
if(n%2==1){
returnt*t*x;
}
returnt*t;
}

再來看一下現在這份代碼時間復雜度是多少呢?

依然還是看他遞歸了多少次,可以看到這里僅僅有一個遞歸調用,且每次都是n/2 ,所以這里我們一共調用了log以2為底n的對數次。

每次遞歸了做都是一次乘法操作,這也是一個常數項的操作,那么這個遞歸算法的時間復雜度才是真正的O(logn)

此時大家最后寫出了這樣的代碼并且將時間復雜度分析的非常清晰,相信面試官是比較滿意的。

總結

對于遞歸的時間復雜度,畢竟初學者有時候會迷糊,刷過很多題的老手依然迷糊。

本篇我用一道非常簡單的面試題目:求x的n次方,來逐步分析遞歸算法的時間復雜度,注意不要一看到遞歸就想到了O(logn)!

同樣使用遞歸,有的同學可以寫出O(logn)的代碼,有的同學還可以寫出O(n)的代碼。

對于function3 這樣的遞歸實現,很容易讓人感覺這是O(logn)的時間復雜度,其實這是O(n)的算法!

intfunction3(intx,intn){
if(n==0){
return1;
}
if(n%2==1){
returnfunction3(x,n/2)*function3(x,n/2)*x;
}
returnfunction3(x,n/2)*function3(x,n/2);
}

可以看出這道題目非常簡單,但是又很考究算法的功底,特別是對遞歸的理解,這也是我面試別人的時候用過的一道題,所以整個情景我才寫的如此逼真,哈哈。

大廠面試的時候最喜歡用“簡單題”來考察候選人的算法功底,注意這里的“簡單題”可并不一定真的簡單哦!

如果認真讀完本篇,相信大家對遞歸算法的有一個新的認識的,同一道題目,同樣是遞歸,效率可是不一樣的!

原文標題:關于遞歸算法的時間復雜度,你還不夠了解

文章出處:【微信公眾號:算法與數據結構】歡迎添加關注!文章轉載請注明出處。

審核編輯:彭靜

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 代碼
    +關注

    關注

    30

    文章

    4898

    瀏覽量

    70584
  • 二叉樹
    +關注

    關注

    0

    文章

    74

    瀏覽量

    12625

原文標題:關于遞歸算法的時間復雜度,你還不夠了解

文章出處:【微信號:TheAlgorithm,微信公眾號:算法與數據結構】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    ADIN2111集成10BASE-T1L PHY的低復雜度、2端口以太網交換機技術手冊

    ADIN2111是一款低功耗、低復雜度、雙以太網端口交換機,它集成了10BASE-T1L PHY和一個串行外設接口(SPI)端口。該器件使用低功率受限節點,面向工業以太網應用且符合IEEE
    的頭像 發表于 05-15 11:41 ?295次閱讀
    ADIN2111集成10BASE-T1L PHY的低<b class='flag-5'>復雜度</b>、2端口以太網交換機技術手冊

    AI時代下芯片復雜度飆升,思爾芯國產硬件仿真加速芯片創新

    引言在人工智能(AI)技術蓬勃發展的今天,芯片的復雜度正以前所未有的速度飆升,輕松跨越了百億邏輯門級別的大關。這一趨勢不僅推動了半導體行業的快速發展,也對硬件仿真系統提出了更高的挑戰和要求。在近日
    的頭像 發表于 12-27 18:01 ?817次閱讀
    AI時代下芯片<b class='flag-5'>復雜度</b>飆升,思爾芯國產硬件仿真加速芯片創新

    芯片設計復雜度劇增,紫光芯片云 3.0 助力企業搭建專業設計環境

    。 ? 實際上,國內中小IC設計企業居多,而如今他們面臨更加復雜的設計需求。隨著芯片制程和規模要求不斷提高,芯片設計環境所需資源越來越大,設計環境構建更加復雜,初創企業如何搭建設計環境,中小企業如何在人員經驗欠缺的情況下完成有效布局,又如
    的頭像 發表于 12-26 17:04 ?1455次閱讀
    芯片設計<b class='flag-5'>復雜度</b>劇增,紫光芯片云 3.0 助力企業搭建專業設計環境

    【「從算法到電路—數字芯片算法的電路實現」閱讀體驗】+內容簡介

    內容簡介這是一本深入解讀基礎算法及其電路設計,以打通算法研發到數字IC設計的實現屏障,以及指導芯片設計工程師從底層掌握復雜電路設計與優化方法為目標的專業技術書。任何芯片(如WiFi芯片、5G芯片
    發表于 11-21 17:14

    【「從算法到電路—數字芯片算法的電路實現」閱讀體驗】+介紹基礎硬件算法模塊

    可能面臨無模塊可買、無高端技術可用的窘境;另一方面,著對較為復雜的核心設計進行攻關,產品生產廠商也對國產自主研發芯片有更大的包容和替代意愿。斷供和提價的壓力。于是形成了一個前所未有的窗口期,芯片廠商有
    發表于 11-21 17:05

    NPU與機器學習算法的關系

    在人工智能領域,機器學習算法是實現智能系統的核心。隨著數據量的激增和算法復雜度的提升,對計算資源的需求也在不斷增長。NPU作為一種專門為深度學習等機器學習任務設計的處理器,其與機器學習算法
    的頭像 發表于 11-15 09:19 ?1181次閱讀

    華納云:Chord算法如何管理節點間的聯系?

    ,以確保網絡變化時后繼關系的正確性。 查找效率: Chord算法通過finger表和后繼指針的設計,使得查找操作的平均時間復雜度為O(log n),其中n是網絡中的節點數量。 通過這些機制,Chord
    發表于 11-08 16:03

    時間復雜度為 O(n^2) 的排序算法

    作者:京東保險 王奕龍 對于小規模數據,我們可以選用時間復雜度為 O(n2) 的排序算法。因為時間復雜度并不代表實際代碼的執行
    的頭像 發表于 10-19 16:31 ?1719次閱讀
    <b class='flag-5'>時間</b><b class='flag-5'>復雜度</b>為 O(n^2) 的排序<b class='flag-5'>算法</b>

    淺談Vivado編譯時間

    隨著FPGA規模的增大,設計復雜度的增加,Vivado編譯時間成為一個不可回避的話題。尤其是一些基于SSI芯片的設計,如VU9P/VU13P/VU19P等,布局布線時間更是顯著增加。當然,對于一些設計而言,十幾個小時是合理的。但
    的頭像 發表于 09-18 10:43 ?2198次閱讀
    淺談Vivado編譯<b class='flag-5'>時間</b>

    PCB與PCBA工藝復雜度的量化評估與應對措施

    一站式PCBA智造廠家今天為大家講講PCBA工藝復雜嗎?PCBA工藝的復雜性應對PCBA工藝復雜性的措施。在電子制造領域,PCBA工藝是至關重要的環節。盡管對許多人來說,PCBA工藝可能看似
    的頭像 發表于 09-13 09:21 ?838次閱讀

    業務復雜度治理方法論--十年系統設計經驗總結

    復雜度量公式 ? ? ? ? ? 子模塊的復雜度cp乘以該模塊對應的開發時間權重值tp,累加后得到系統的整體復雜度C 這里的子模塊復雜度 c
    的頭像 發表于 09-05 14:11 ?1301次閱讀
    業務<b class='flag-5'>復雜度</b>治理方法論--十年系統設計經驗總結

    納芯微柵極驅動IC產品手冊發布

    每一個功率器件都需要相應的驅動芯片,選擇合適的驅動芯片可以簡化系統設計,減少設計復雜度,并節省研發時間。
    的頭像 發表于 08-19 17:23 ?1027次閱讀
    納芯微柵極驅動IC產品手冊發布

    Python遞歸的經典案例

    當我們碰到諸如需要求階乘或斐波那契數列的問題時,使用普通的循環往往比較麻煩,但如果我們使用遞歸時,會簡單許多,起到事半功倍的效果。這篇文章主要和大家分享一些和遞歸有關的經典案例,結合一些資料談一下個人的理解,也借此加深自己對遞歸
    的頭像 發表于 08-05 15:57 ?706次閱讀

    CISC(復雜指令集)與RISC(精簡指令集)的區別  

    復雜度, 將復雜性交給編譯器。舉一個例子,CISC提供的乘法指令,調用時可完成內存a和內存b中的兩個數相乘,結果存入內存a ,需要多個CPU周期才可以完成;而RISC不提供“一站式”的乘法指令,需
    發表于 07-30 17:21

    遞歸神經網絡的實現方法

    遞歸神經網絡(Recursive Neural Network,簡稱RNN)是一種特殊類型的神經網絡,其特點在于能夠處理具有層次或樹狀結構的數據,并通過遞歸的方式對這些數據進行建模。與循環神經網絡
    的頭像 發表于 07-10 17:02 ?775次閱讀
    主站蜘蛛池模板: 亚洲欧美v视色一区二区 | 一级黄色录像毛片 | 国产高清色视频免费看的网址 | 美女黄18以下禁止观看 | 国产精品免费久久 | 中日韩精品视频在线观看 | 国产在线97色永久免费视频 | 免费看国产一级特黄aa大片 | 猛操女人| 精品一区二区三区免费毛片爱 | 深爱激情五月网 | 婷婷影院在线综合免费视频 | 免费网站黄成人影院 | 性欧美高清强烈性视频 | 欧美性极品高清 | 亚洲天堂视频在线播放 | 四虎影院免费观看 | 手机看高清特黄a大片 | 天堂中文在线最新版地址 | 成年在线视频 | 最好看免费中文字幕2018视频 | 亚洲αv久久久噜噜噜噜噜 亚洲аv电影天堂网 | 天堂网在线看 | 人人97| 黄色短视频免费看 | 日韩一区二区三区免费 | 亚洲jizzjizz在线播放久 | 日日添天天做天天爱 | 天天摸天天做天天爽 | 天天插天天舔 | 天天爽天天色 | 日本一区二区三区在线观看视频 | 欧美一级特黄视频 | 天天干天天插天天 | 色综合久久久久久久久久久 | 台湾一级毛片 | 国产成人无精品久久久久国语 | 欧美爽妇| 手机在线观看免费视频 | 成人亚洲精品 | 激情网五月 |