遞歸算法常見問題(Java)

問題:斐波那契數列,第1項和第2項都為1,后面每一項都為相鄰的前倆項的和,求第n個數

解法:每一個數都為前倆個數之和,第1項和第2項都為1,所以寫 方法f1(n)即為求第n個數,那么f1(n-1)為求第n-1個數,f(n-2)為第n-2個數。所以f1(n)=f1(n-1)+f1(n-2),然后設置出口,n=1或者n=2時返回1。

public class Test2 {public static void main(String[] args) {System.out.println(f1(6));}//斐波那契數列,第1項和第2項都為1,后面每一項都為相鄰的前倆項的和,求第n個數//f1為求第n個數,第n個數為第n-1個數加上第n-2個數static int f1(int n){if(n==1||n==2)return 1;return f1(n-1)+f1(n-2);}
}

問題:求m和n的最大公約數,m>n

解法:若m%n=0,則n即最大公約數,若為k,則m與n的最大公約數可轉換為?n與k的最大公約數

public class Test2 {public static void main(String[] args) {System.out.println(f2(36, 24));}//斐波那契數列,第1項和第2項都為1,后面每一項都為相鄰的前倆項的和,求第n個數//f1為求第n個數,第n個數為第n-1個數加上第n-2個數static int f2(int m,int n){if(m%n==0)return n;return f2(n,m%n);}
}

問題:對無序數組arr進行排序,arr數組大小為k

解法:對無序數組arr排序 等價于 對前k-1個元素排序后,在對第k個元素插入排序。先進行第1個元素和第2個元素的排序,然后對第3個元素插入排序,然后對第4個元素插入排序....不斷遞歸。

public class Test2 {public static void main(String[] args) {int[] arr= new int[]{9,9,7,6,5,4,3,2,1};f3(arr,arr.length-1);for (int i : arr) {System.out.println(i);}}static void f3(int[] arr,int k){if(k==0)return;//對前k-1個元素進行排序f3(arr,k-1);//把位置k的元素插到前面int x=arr[k];int index=k-1;while(index>=0 && x<arr[index]){arr[index+1]=arr[index];index--;}arr[index+1]=x;}
}

問題:漢諾塔

將1~N從a移動到c,b作為輔助
等價于:將1~N-1從a移動到b,將N移動到c,這時a為空,c為空(此時c有N但因為N不用動了,所以看作為空),然后在把1~N-1移動到c,a為輔助。

public class Test2 {public static void main(String[] args) {f4(3,"A","C","B");}//N個小盤子,from初始柱子,to目標柱子,help輔助柱子static void f4(int n,String from,String to,String help){if(n==1){System.out.println("move"+n+"from"+from+"to"+to);}else {f4(n-1,from,help,to); //把前n-1個盤子移到輔助柱子上System.out.println("move"+n+"from"+from+"to"+to);//n號盤子可以到達目標柱子f4(n-1,help,to,from); //n-1個盤子回到目標柱子}}
}

問題:上樓梯、一共n階,一次性可以上1階、2階或3階,問多少種走樓梯的方法

?上第n階時,有三種情況,它可以從第n-1階上1階、從第n-2階上2階、從第n-3階上3階。

所有f(n)=f(n-1)+f(n-2)+f(n-3)。

public class Test2 {public static void main(String[] args) {System.out.println(f1(8));}static int f1(int n){if(n==1)return 1;if(n==2)return 2;if(n==3)return 4;return f1(n-3)+f1(n-2)+f1(n-1);}
}

問題:旋轉數組,把一個遞增數組的前若干個序列搬到該數組的最后,比如{1,2,3,4,5}->{3,4,5,1,2},求該數組的最小值

解法:最小值一定在無序的那一半中。

public class Test2 {public static void main(String[] args) {}//最小值一定在無序的那一半中。static int f2(int[] arr){int begin=0,end=arr.length-1;//考慮沒有旋轉這種特殊旋轉if(arr[begin]<arr[end])return arr[begin];while(begin+1<end){int mid=begin+((end-begin)>>1);if(arr[mid]>arr[begin]){ //左側為有序begin=mid;}else{ //右側有序end=mid;}}return arr[end];}
}

問題:在給定一個無序的數組中,找出最長連續遞增的子序列

解法:找到第一個遞增子序列的長度,然后遞歸下一個遞增子序列的長度,直到遍歷完數組

public class Test2 {public static void main(String[] args) {int[] arr = new int[]{1,9,4,5,6,7,8,9,3,6,7};int[]ans=f4(arr,0);for(int i=0;i<ans.length;i++){System.out.println(ans[i]);}}static int[] f4(int[] arr,int start){if(start>=arr.length)return new int[]{};int count=1,index=start;while(index<arr.length-1 &&arr[index+1]>arr[index]){index++;count++;}int[] ans= new int[count];for(int i=start;i<start+count;i++){ans[i-start]=arr[i];}int[] a=f4(arr,start+count);return count>a.length?ans:a;}
}

問題:設計一個高效的求a的n次冪的算法

public class Test2 {public static void main(String[] args) {int n = -3int ans=f5(2,Math.abs(n));System.out.println(n>=0?ans:("1/"+ans));}static int f5(int a,int n){if(n==0)return 1;int ans=a;int ex=1;//指數while((ex<<1)<=n){ans*=ans;ex<<=1;}//差n-ex次方ans*=f5(a,n-ex);return ans;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/64095.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/64095.shtml
英文地址,請注明出處:http://en.pswp.cn/web/64095.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

git自動壓縮提交的腳本

可以將當前未提交的代碼自動執行 git addgit commitgit squash Git 命令安裝指南 1. 創建腳本目錄 如果目錄不存在&#xff0c;創建它&#xff1a; mkdir -p ~/.local/bin2. 創建腳本文件 vim ~/.local/bin/git-squash將完整的腳本代碼復制到此文件中。 3. 設置腳本權限…

C項目 天天酷跑(下篇)

上篇再博客里面有&#xff0c;接下來我們實現我們剩下要實現的功能 文章目錄 碰撞檢測 血條的實現 積分計數器 前言 我們現在要繼續優化我們的程序才可以使這個程序更加的全面 碰撞的檢測 定義全局變量 實現全局變量 void checkHit() {for (int i 0; i < OBSTACLE_C…

論文解讀——掌紋生成網絡 RPG-Palm升級版PCE-Palm

該文章是2023年論文RPG-Palm的升級版 論文&#xff1a;PCE-Palm: Palm Crease Energy Based Two-Stage Realistic Pseudo-Palmprint Generation 作者&#xff1a;Jin, Jianlong and Shen, Lei and Zhang, Ruixin and Zhao, Chenglong and Jin, Ge and Zhang, Jingyun and Ding,…

代碼隨想錄算法【Day2】

Day2 1.掌握滑動窗口法 2.模擬題&#xff0c;堅持循環不變量原則 209 長度最小的子數組 暴力法&#xff1a; class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {//暴力法int i, j; //i代表起始點&#xff0c;j代表終止點int sum; //…

android——屏幕適配

一、屏幕適配的重要性 在 Android 開發中&#xff0c;屏幕適配是非常關鍵的。因為 Android 設備具有各種各樣的屏幕尺寸、分辨率和像素密度。如果沒有進行良好的屏幕適配&#xff0c;應用可能會出現顯示不完整、元素拉伸或壓縮變形、字體大小不合適等問題&#xff0c;極大地影響…

oscp學習之路,Kioptix Level2靶場通關教程

oscp學習之路&#xff0c;Kioptix Level2靶場通關教程 靶場下載&#xff1a;Kioptrix Level 2.zip 鏈接: https://pan.baidu.com/s/1gxVRhrzLW1oI_MhcfWPn0w?pwd1111 提取碼: 1111 搭建好靶場之后輸入ip a看一下攻擊機的IP。 確定好本機IP后&#xff0c;使用nmap掃描網段&…

第二十六周機器學習筆記:PINN求正反解求PDE文獻閱讀——正問題

第二十六周周報 摘要Abstract文獻閱讀《Physics-informed neural networks: A deep learning framework for solving forward and inverse problems involving nonlinear partial differential equations》1. 引言2. 問題的設置3.偏微分方程的數據驅動解3.1 連續時間模型3.1.1 …

【安全編碼】Web平臺如何設計防止重放攻擊

我們先來做一道關于防重放的題&#xff0c;答案在文末 防止重放攻擊最有效的方法是&#xff08; &#xff09;。 A.對用戶密碼進行加密存儲使用 B.使用一次一密的加密方式 C.強制用戶經常修改用戶密碼 D.強制用戶設置復雜度高的密碼 如果這道題目自己拿不準&#xff0c;或者…

中關村科金智能客服機器人如何解決客戶個性化需求與標準化服務之間的矛盾?

客戶服務的個性化和標準化之間的矛盾一直是一個挑戰。一方面&#xff0c;企業需要提供標準化的服務以保持運營效率和成本控制&#xff1b;另一方面&#xff0c;為了提升客戶滿意度和忠誠度&#xff0c;企業又必須滿足客戶的個性化需求。為此&#xff0c;中關村科金推出了智能客…

OPPO Android面試題及參考答案 (上)

性能優化方面,講一下圖片內存占用計算,以及如何避免持有不必要的引用。 在 Android 中,計算圖片內存占用主要與圖片的尺寸和像素格式有關。對于一張位圖(Bitmap),其內存占用大小可以通過以下方式估算:內存占用 = 圖片寬度 圖片高度 每個像素占用字節數。例如,常見的 …

Agent 案例分析:金融場景中的智能體-螞蟻金服案例(10/30)

Agent 案例分析&#xff1a;金融場景中的智能體 —螞蟻金服案例 一、引言 在當今數字化時代&#xff0c;金融行業正經歷著深刻的變革。隨著人工智能技術的飛速發展&#xff0c;智能體&#xff08;Agent&#xff09;在金融場景中的應用越來越廣泛。螞蟻金服作為金融科技領域的…

ElasticSearch 的工作原理

理解 ElasticSearch 的工作原理需要從索引、搜索、以及其背后的核心機制幾個方面來探討。 1. ElasticSearch 是什么&#xff1f; ElasticSearch 是一個分布式搜索和分析引擎&#xff0c;適用于各種類型的數據&#xff0c;例如文本、數值、地理位置、結構化或非結構化數據。它基…

STM32F407 | Embedded IDE01 - vscode搭建Embedded IDE開發環境(支持JLINK、STLINK、DAPLINK)

導言 Embedded IDE官網:https://em-ide.com/docs/intro 我猜肯定有部分人使用SI Keil開發STM32項目&#xff0c;也有vscode Keil開發STM32程序。SI或vscode編寫代碼&#xff0c;然后切換Keil編譯、下載、調試程序。有一段時間&#xff0c;我也是這么干的。但是&#xff0c;程…

光譜相機的工作原理

光譜相機的工作原理主要基于不同物質對不同波長光的吸收、反射和透射特性存在差異&#xff0c;以下是其具體工作過程&#xff1a; 一、光的收集 目標物體在光源照射下&#xff0c;其表面會對光產生吸收、反射和透射等相互作用。光譜相機的光學系統&#xff08;如透鏡、反射鏡…

ThinkPHP接入PayPal支付

ThinkPHP 5接入PayPal 支付&#xff0c;PayPal的流程是服務器請求Paypal的接口下單&#xff08;需要傳訂單id/支付成功的重定向地址/支付失敗的重定向地址&#xff09;&#xff0c;接會返回一個支付地址&#xff0c;項目服務器把地址返給用戶&#xff0c;用戶打開鏈接登錄Paypa…

stream流的toMap

假設有這么一個類: import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors;public class Student {private int id;private String name;public Student(int id, String name) {this.id id;…

html + css 淘寶網實戰

之前有小伙伴說&#xff0c;淘寶那么牛逼你會寫代碼&#xff0c;能幫我做一個一樣的淘寶網站嗎&#xff0c;好呀&#xff0c;看我接下來如何給你做一個淘寶首頁。hahh,開個玩笑。。。學習而已。 在進行html css編寫之前 先了解下網頁的組成和網頁元素的尺寸吧 1.網頁的組成 …

神經網絡、深度學習、卷積神經網絡

好的&#xff01;我會盡量詳細且易懂地為你解釋這些概念&#xff0c;并在最后用簡單直白的語言總結一下。 1. 神經網絡思想 神經網絡是靈感來自于生物大腦神經元的工作原理&#xff0c;是一種模仿人類大腦處理信息的方式來設計的數學模型。我們的大腦由億萬個神經元組成&…

設計模式01:創建型設計模式之單例、簡單工廠的使用情景及其基礎Demo

一、單例模式 1.情景 連接字符串管理 2.好處 代碼簡潔&#xff1a;可全局訪問連接字符串。性能優化&#xff1a;一個程序一個連接實例&#xff0c;避免反復創建對象&#xff08;連接&#xff09;和銷毀對象&#xff08;連接&#xff09;。線程安全&#xff1a;連接對象不會…

【不太正常的題】LeetCode.232:用棧的函數接口實現隊列

&#x1f381;個人主頁&#xff1a;我們的五年 &#x1f50d;系列專欄&#xff1a;初階數據結構刷題 &#x1f389;歡迎大家點贊&#x1f44d;評論&#x1f4dd;收藏?文章 &#x1f697; 1.問題描述&#xff1a; 題目中說了只能使用兩個棧實現隊列&#xff0c;并且只能使用…