遞歸相關知識2

来源:https://www.cnblogs.com/cgy-chen/archive/2023/07/14/17554984.html
-Advertisement-
Play Games

# 遞歸相關知識2 ## 多路遞歸--斐波那契額數列 ```java import java.util.Arrays; //遞歸求斐波那契第n項 public class feibonaqie { public static int fibonacci(int n){ int []cache=new ...


遞歸相關知識2

多路遞歸--斐波那契額數列

import java.util.Arrays;

//遞歸求斐波那契第n項
public class feibonaqie {
    public static int fibonacci(int n){
        int []cache=new int[n+1];
        Arrays.fill(cache,-1);
        cache[0]=0;
        cache[1]=1;//[0,1,-1,-1,-1,-1]
        return f(n,cache);
    }

    public static int f(int n,int[]cache){
     /*   if(n==0){
            return 0;
        }
        if(n==1){
            return 1;
        }*/
        if(cache[n]!=-1){
            return cache[n];
        }
        int x=f(n-1,cache);
        int y=f(n-2,cache);
        cache[n]=x+y;
        return cache[n];
    }

    /*public static void main(String[] args) {
        int f=f(8);
        System.out.println(f);
    }*/
}

漢諾塔問題

import java.util.LinkedList;

public class hannuota {
    static LinkedList<Integer> a=new LinkedList<>();//三根柱子
    static LinkedList<Integer> b=new LinkedList<>();
    static LinkedList<Integer> c=new LinkedList<>();

    //3 2 1

    static void init(int n){
        for(int i=n;i>=1;i--){
            a.addLast(i);
        }
    }
     /*
     Params:n-圓席個數
a-源
b-信
c-目
      */

    static void move(int n,LinkedList<Integer> a,LinkedList<Integer> b,
                     LinkedList<Integer> c){
        if(n==0){
            return;
        }
       move(n-1,a,c,b);
        c.addLast(a.removeLast());//中間
        print();
        move(n-1,b,a,c);
    }
    public static void main(String[]args){
        init(3);
      /*  System.out.println(a);
        System.out.println(b);
        System.out.println(c);
        b.addLast(a.removeLast());*/
        print();
        move(3,a,b,c);
    }




    private static void print() {
        System.out.println("----------------------");
        System.out.println(a);
        System.out.println(b);
        System.out.println(c);
    }
}

爆棧問題

//遞歸求和n+n-1+...+1
public class baozhan {
    //f(n)=f(n-2)+n;


    public static long sum(long n){
     if(n==1){
         return 1;
     }
     return sum(n-1)+n;
    }

    public static void main(String[] args) {
       /* System.out.println(sum(15000));*///爆棧
    }
}

楊輝三角

第一種,時間複雜度最高,空間複雜度最高

public class yanghuisanjiao {

    private static int element(int i,int j){
        if(j==0||i==j){
            return 1;
        }
        return element(i-1,j-1)+element(i-1,j);
    }
 private static void printSpace(int n,int i){
        int num=(n-1-i)*2;
     for (int j = 0; j < num; j++) {
         System.out.print(" ");
     }
 }
    public static void print(int n){
        for (int i = 0; i < n; i++) {
            printSpace(n,i);
            for (int j = 0; j <= i; j++) {
                System.out.printf("%-4d",element(i,j));
            }
            System.out.println();
        }
    }
    public static void main(String[] args) {
      /*  System.out.println(element(4,2));*/
        print(5);
    }
}

第二種--時間複雜度降低,空間複雜度提升

public class yanghuisanjiao1 {
/*
優化1·使用二組數組記憶法
Params:triangle-二維數組
i-行坐標
j-列坐標
Returns:該坐標元素值
 */
    private static int element1(int[][]triangle,int i,int j){
        if(triangle[i][j]>0){
            return triangle[i][j];
        }
        if(j==0||i==j){
            triangle[i][j]=1;
            return 1;
        }
        triangle[i][j]=element1(triangle,i-1,j-1)+element1(triangle,i-1,j);
        return triangle[i][j];
    }
 private static void printSpace(int n,int i){
        int num=(n-1-i)*2;
     for (int j = 0; j < num; j++) {
         System.out.print(" ");
     }
 }
    public static void print(int n){
        int[][]triangle=new int[n][];
        for (int i = 0; i < n; i++) {//行
            triangle[i]=new int[i+1];
         /*   printSpace(n,i);*/
            for (int j = 0; j <= i; j++) {
                System.out.printf("%-4d",element1(triangle,i,j));
            }
            System.out.println();
        }
    }
    public static void main(String[] args) {
      /*  System.out.println(element(4,2));*/
        print(5);
    }
}

時間複雜度,空間複雜度同時提升

public class yanghuisanjiao2 {
/*
優化2·使用二組數組記憶法
Params:triangle-二維數組
i-行坐標
j-列坐標
Returns:該坐標元素值
 */


    //動態規劃--註意:還可以透過每一行的前一項計算半下一項,不必藉助上一行,這與楊輝三角的另一個特性有關,
 /*   private static int element1(int[][]triangle,int i,int j){
        if(triangle[i][j]>0){
            return triangle[i][j];
        }
        if(j==0||i==j){
            triangle[i][j]=1;
            return 1;
        }
        triangle[i][j]=element1(triangle,i-1,j-1)+element1(triangle,i-1,j);
        return triangle[i][j];
    }
 private static void printSpace(int n,int i){
        int num=(n-1-i)*2;
     for (int j = 0; j < num; j++) {
         System.out.print(" ");
     }
 }*/
    public static void print2(int n){
       int[]row=new int[n];
        for (int i = 0; i < n; i++) {//行
      /*      triangle[i]=new int[i+1];*/
         /*   printSpace(n,i);*/
            createRow(row,i);
            for (int j = 0; j <= i; j++) {
                System.out.printf("%-4d",row[j]);
            }
            System.out.println();
        }
    }
    private static void createRow(int[]row,int i){
        if(i==0){
            row[0]=1;
            return;
        }
        for (int j = i; j >0 ; j--) {
            row[j]=row[j]+row[j-1];
        }
    }

    public static void main(String[] args) {
      /*  System.out.println(element(4,2));*/
        print2(5);
    }
}

數據結構素數實現

class FuShu{
    int real; //實部real、虛部image;
    int image;
    FuShu(int real, int image) { //構造方法:賦初值;
        this.real = real;
        this.image = image;
    }

    FuShu add(FuShu s1) { // 加法運算 FuShu add(FuShu s1);
        FuShu tmp = new FuShu(real + s1.real, image + s1.image);
        return tmp;
    }
}

public class xubu {
    public static void main(String[] args) { //兩個複數相加,輸出結果
        FuShu s1 = new FuShu(1, 2);
        FuShu s2 = new FuShu(2, 3);
        FuShu s3 = s2.add(s1);
        System.out.println(s3.real + " + " + s3.image + "i");
    }

}


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

-Advertisement-
Play Games
更多相關文章
  • ![你真的瞭解bind嗎](https://guizimo.oss-cn-shanghai.aliyuncs.com/img/%E4%BD%A0%E7%9C%9F%E7%9A%84%E4%BA%86%E8%A7%A3bind%E5%90%97.png) # 引言 ## 內容速遞 > 看了本文您能瞭解 ...
  • 對於各種類型的埋點來說,曝光埋點往往最為複雜、需要用到的技術也最全面、如果實現方式不合理可能造成的影響也最大,因此本文將重點介紹曝光埋點尤其是長列表(或滾動視圖)內元素曝光埋點的實現思路及避坑技巧 ...
  • # window.localStorage.setItem 和 localStorage.setItem 有什麼區別 - 在JavaScript中,localStorage.setItem和window.localStorage.setItem實際上是相同的, - 它們是對瀏覽器的本地存儲(Loca ...
  • 基於tauri+vite4+pinia2跨端後臺管理系統應用實例TauriAdmin。 tauri-admin 基於最新跨端技術 Tauri Rust webview2 整合 Vite4 構建桌面端通用後臺管理解決方案。搭載輕量級ve-plus組件庫、支持多視窗切換管理、vue-i18n多語言包、動 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 前言 最近剛剛學習了Echarts的使用,於是想做一個小案例來鞏固一下。項目效果如下圖所示: 話不多說,開始進入實戰。 創建項目 這裡我們使用vue-cli來創建腳手架: vue create app 這裡的app是你要創建的項目的名稱, ...
  • 推薦使用壓縮軟體和殺毒軟體 7 - zip 使用火絨 # 一、基本數據類型與變數(上) ### 2.1 註釋 優點: 1. 代碼說明 沒註釋的代碼 有註釋的代碼 1. 不讓解釋器執行註釋的那句話 ### 2.2 單行註釋 單行註釋快捷鍵:ctrl + ? ### 2.3多行註釋 """""" (三個 ...
  • 先上java代碼: 先上java代碼: import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.*; import java.util.Sc ...
  • # 一、簡介 ## 1.前置知識 ● Java17 ● Spring、SpringMVC、MyBatis ● Maven、IDEA ## 2.環境要求 | 環境&工具 | 版本(or later) | | : : | : : | | SpringBoot | 3.1.x | | IDEA | 202 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...