每天兩題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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...