每天兩題01

来源:https://www.cnblogs.com/wyq1995/archive/2019/09/16/11530937.html
-Advertisement-
Play Games

又是兩個月的時間過去了,上一次寫博客是7月14號,時間還是過的很快的,那麼問題來了,為什麼這麼長時間都沒有寫東西了呢?難道是在打醬油? 哈哈,說起來很慚愧,剛剛開始工作,碰到各種的問題要去學習要去解決,然後業餘的時間又去學了一些奇奇怪怪的東西,導致博客一直都落下了,歸根到底,還是自己懶惰了,因為心中 ...


  又是兩個月的時間過去了,上一次寫博客是7月14號,時間還是過的很快的,那麼問題來了,為什麼這麼長時間都沒有寫東西了呢?難道是在打醬油?

  哈哈,說起來很慚愧,剛剛開始工作,碰到各種的問題要去學習要去解決,然後業餘的時間又去學了一些奇奇怪怪的東西,導致博客一直都落下了,歸根到底,還是自己懶惰了,因為心中總覺得今天又工作了一天,下班了要好好放鬆一下。不自覺的用這種心理在安慰自己,使得自己越來越放鬆了,然後又因為自己有點拖延症,想要寫點東西就一直拖著。。。

  ╮( ̄▽ ̄")╭哎,話不多說了,最近源碼什麼的看的多了總覺得自己基礎還是不夠扎實,就想著業餘打打基礎,上班時間再看看框架寫寫業務邏輯什麼的應該比較好,每天打基礎的東西不多,就兩個題,貪多嚼不爛,題目選自劍指offer,有興趣的可以在github中自己看看哦,鏈接:https://github.com/CyC2018/CS-Notes

 

第一題:斐波那契數列

  題目描述:大家都知道斐波那契數列,現在要求輸入一個整數n,請你輸出斐波那契數列的第n項。 n<=39

  

  我的思路:什麼是斐波那契數列應該還是知道一點的,公式如上圖所示;簡單的來說就是從第三個數開始,任意一個數等於前面兩個數之和,比如0,1,1,2,3,5,8,13,22.......那麼最簡單的思路就是用遞歸,看下麵代碼:

public class Study01 {

    public static int feibo(int n){
        //要有下麵這兩個if,記住遞歸的話要有出口,然後會有死迴圈
        if (n==0) {
            return 0;
        }
        if (n==1 || n==2) {
            return 1;
        }
        return feibo(n-1)+feibo(n-2);
    }
    
    public static void main(String[] args) {
        
        int res = feibo(6);
        System.out.println(res);//8

    }
}

   上面的代碼寫出來了,但是可不可以優化一下,因為遞歸會導致一些值重覆的計算,例如計算feibo(5)=feibo(4)+feibo(3)=[ feibo(3)+ feibo(2)]  + feibo(3),然後這裡電腦會計算兩次feibo(3),這裡電腦可不會像人一樣合併同類項然後計算啊,而一旦計算feibo(n),當n的值很大的時候,在遞歸計算過程中就會有很多的這種重覆計算的數,那麼我們有沒有辦法將這種重覆計算的數給剔除呢?只計算一次然後存起來,下一次再計算的話直接去拿就好了;

  

  改進1:新建一個數組,我們從n=0開始,將每次算出來的數放到數組中,那麼數組中第n個位置的數就是我們需要的結果

//改進方式1
    public static int feiboUp01(int n){
        if (n==0) {
            return 0;
        }
        if (n==1 || n==2) {
            return 1;
        }
        int[] arr = new int[n+1];
        arr[0]=0;
        arr[1]=1;
        arr[2]=1;
        //這個迴圈每一次都會就算出來一個值填充到數組中,直到算出arr[n]
        for (int i = 3; i <= n; i++) {
            arr[i]=arr[i-1]+arr[i-2];
        }
        return arr[n];
    }
    
    public static void main(String[] args) {
        
        int res = feiboUp01(6);
        System.out.println(res);//8

    }

 

  

  改進二:不知道有沒有發現上面這種做法雖然巧妙的利用了數組,但是對於我們來說,除了數組中的最後一個數,其他的數都是沒有什麼必要的,難道計算一個非常大的n,就要new一個這麼大的數組嗎?所以我們還可以繼續改進一下;

//改進方式2
    public static int feiboUp02(int n){
        if (n==0) {
            return 0;
        }
        if (n==1 || n==2) {
            return 1;
        }
        //這裡的三個變數,比如0,1,1,2,3,5,當current為5的時候,pre就是3,prepre就是2
        int prepre=1;
        int pre=1;
        int current = 0;
        //這裡有點不好理解,三個數prepre    pre    current
        //經過一次迴圈,計算current = prepre+pre,這個時候也要將prepre和pre往右移動一個位置,將
        //原來的pre指向現在的current,原來的prepre指向現在的pre
        for (int i = 3; i <= n; i++) {
            current = prepre+pre;
            prepre = pre;
            pre = current;
        }
        return current;
    }
    public static void main(String[] args) {
        
        int res = feiboUp02(6);
        System.out.println(res);

    }

 

 

 第二題:我們可以用 2x1 的小矩形橫著或者豎著去覆蓋更大的矩形。請問用 n 個 2x1 的小矩形無重疊地覆蓋一個 2xn 的大矩形,總共有多少種方法?

  這個問題其實還是斐波那契數列,但是思路很有趣,一般我們想辦法計算有多少種方法的時候,可能就去畫圖計算去了,但是這裡卻是將一個大的問題拆成子問題,而子問題可以繼續拆...

  如果n=1,只有一種情況,

  如果n=2,只有兩種,兩塊都橫著或者兩塊都豎著

 

   

  假如n=3,那麼問題就變成用 3個 2x1 的小矩形無重疊地覆蓋一個 2x3 的大矩形,第一種情況,填充的那一塊是橫著放的,如下所示,那麼剩下的需要填充的就是相當於n=2的情況,即2x2的情況;第二種情況就是第一塊填充的是豎著放的,那麼還需要再填充一塊,那麼剩下的就是n=1的情況;

             

 

   依次類推,當n=5的時候也有兩種情況,第一種情況橫著填充一塊,剩下的就是n=4的那種;第二種情況豎著填充兩塊,剩下的就是相當於n=3的那種,通用公式如下,就不多說了,代碼的話和上面基本一樣,就不多說了。。。

 

 

 

   這兩個題目還是很有意思的,可以說一個題目是讓你看公式寫代碼,而另外一個題目其實用的是分治法,所謂的分治法,就是分而治之。就是將原問題劃分為n個規模較小,結構與原問題類似的小問題進行處理,遞歸地解決這些問題,然後再合併求解的過程。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 JavaServer Pages(JSP)技術使Web開發人員和設計人員能夠快速開發和輕鬆維護利用現有業務系統的信息豐富的動態Web頁面。 作為Java技術系列的一部分,JSP技術可以快速開發獨立於平臺的基於Web的應用程式。JSP技術將用戶界面與內容生成分開,使設計人員能夠在不改變底層動態內 ...
  • FreeMarker 介紹 Apache FreeMarker™是一個 模板引擎 :一個Java庫,用於根據模板和更改數據生成文本輸出(HTML網頁,電子郵件,配置文件,源代碼等)。模板是用FreeMarker模板語言(FTL)編寫的,這是一種簡單的專用語言(不像PHP這樣的完整編程語言)。通常,使 ...
  • 最好有其他web框架基礎,不推薦小白閱讀, 1.視圖函數 1.1視圖函數的返回值 django要求視圖函數必須返回一個HTTPResponse對象,render函數和 redirect 函數其實都是返回了一個特定的HTTPResponse對象 1.2 reder函數 render函數用於渲染一個模板 ...
  • 使用工具:IronPython 工具介紹:是一種在 .NET 及 Mono上的 Python 實現,是一個開源的項目,基於微軟的 DLR 引擎。(個人理解就是在 .net上面運行Python代碼) 使用方法:先新建一個控制台應用程式 => 使用Nuget 添加IronPython包 => 在Main ...
  • 1、元素的分類 需求:有如下集合[11,22,33,44,55,66,77,88,99,90……],將所有大於66的值保存在字典的第一個key中,將小於66的值保存在第二個key的值中 代碼實現: 1 #定義一個list列表 2 li = [11,22,33,44,55,66,77,88,99,90 ...
  • 2019-09-16-23:09:06 自學Python的第六天,也是寫博客的第六天 今天學的內容是有關dict字典的用法 看視頻加上練習,目前還沒遇到有難點,但是感覺很不好的樣子 沒有難點以後突然出現一個有關字典的程式感覺要炸,還是得繼續掌握 看最後的代碼吧,有更好的請告訴我 我 是 一 條 快 ...
  • 一:MonoDB的簡單介紹 MongoDB是一個介於關係型資料庫與非關係型資料庫中間的資料庫,是使用C++進行編寫的,他的優點是在支持的查詢格式特別的強大,可以進行存儲比較複雜的數據類型,支持建立索引 二:下載 官方地址:https://www.mongodb.com/ 本教程下載 3.4版本:ht ...
  • Python分散式爬蟲必學框架Scrapy打造搜索引擎 部分課程截圖: 點擊鏈接或搜索QQ號直接加群獲取其它資料: 鏈接:https://pan.baidu.com/s/1-wHr4dTAxfd51Mj9DxiJ4Q 提取碼:ik1n 免費分享,如若鏈接失效請加群 其它資源在群里,私聊管理員即可免費 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...