摘要:題目的方格從左上角走到右下角只能向右向下走一共有多少種走法圖形題目轉(zhuǎn)化為圖形之后就是,從方格走到方格有多少種方案每次走一格分析根據(jù)題目我們知道只能往右走或者向下走,那么從,格子走到,格子只有一種方案,從,格子走到,格子也只有一種方案。
題目:3X4的方格 從左上角A走到右下角B 只能向右向下走 一共有多少種走法?
圖形:題目轉(zhuǎn)化為圖形之后就是,從(1, 1)方格走到(3, 4)方格有多少種方案(每次走一格)?
分析:
1、根據(jù)題目我們知道只能往右走或者向下走,那么從(2, 4)格子走到(3, 4)格子只有一種方案,從(3, 3)格子走到(3, 4)格子也只有一種方案。
2、以此類推,到某個格子A的走法 = A上面的格子走法 + A左邊的格子走法;
3、如果碰到第一行或者第一列的格子,那么走法只有一種
4、如果碰到第一個格子,我們認為不需要走,即走法為0
總結:
1、這種把一個復雜的問題分解成若干個有相同規(guī)律的子問題的方法,我們稱之為遞歸。
2、遞歸由遞歸條件和遞歸出口組成,其中遞歸出口非常重要。
3、分析中的第2點我們稱之為遞歸條件。
4、分析中的點3、4點我們稱之為遞歸出口(返回明確的值)。
代碼:
// N X M的方格 從左上角A(1, 1)走到右下角B(N, M) 只能向右向下走 一共有多少種走法? function calc(x, y){ // 坐標(1, 1) 遞歸出口 if(x == 1 && y == 1) return 0; // 坐標(x, 1) (1, y) 遞歸出口 if(x == 1 || y == 1) return 1; // 遞歸條件 if(x > 1 && y > 1) { return calc(x-1, y) + calc(x, y-1); } // 不符合條件,直接返回0 return 0; } calc(3, 4); // 10
問題:
根據(jù)上面的分析,我們知道在遞歸的過程中,會有很多重復的格子,非常浪費性能,當計算的數(shù)字越大,遞歸的性能也會越低,怎么提高遞歸的性能呢?下次我們再介紹(剪枝)。
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/104372.html
摘要:動態(tài)規(guī)劃算法通?;谝粋€遞推公式及一個或多個初始狀態(tài)。動態(tài)規(guī)劃有三個核心元素最優(yōu)子結構邊界狀態(tài)轉(zhuǎn)移方程我們來看一到題目題目有一座高度是級臺階的樓梯,從下往上走,每跨一步只能向上級或者級臺階。 概念 動態(tài)規(guī)劃(dynamic programming)是運籌學的一個分支,是求解決策過程(decision process)最優(yōu)化的數(shù)學方法。動態(tài)規(guī)劃算法通?;谝粋€遞推公式及一個或多個初始狀態(tài)...
摘要:我記得大三參加騰訊的校招面試時只準備了幾種常見的排序算法就足以應對了,然而今年包括今日頭條在內(nèi)的多家大廠的前端筆試題目中都出現(xiàn)了貪心算法動態(tài)規(guī)劃分治算法等進階性的算法題目。本篇博客參考今日頭條銀國徽老師的《js版數(shù)據(jù)結構與算法》Part1改編自《漫畫算法》原作者:程序員小灰前言眾所周知,與后臺開發(fā)人員相比,算法是我們前端開發(fā)人員的一個弱項。而近兩年隨著互聯(lián)網(wǎng)行業(yè)競爭愈發(fā)激烈,市場上對前端崗位...
摘要:有關排列組合的一道算法題一題目內(nèi)容廢話不多說,先上題目有一個的網(wǎng)格,左下角為,右上角為,規(guī)定每次只能走一步,并且方向只能是向上或者向右,求到共有多少種走法例如一個日字形的格子就是一個的網(wǎng)格,共有種走法并用寫出程序算法。 有關排列組合的一道算法題 一、題目內(nèi)容 廢話不多說,先上題目: 有一個 n × m 的網(wǎng)格,左下角為A,右上角為B,規(guī)定每次只能走一步,并且方向只能是向上或者向右,求A...
摘要:而眾所周知,馬是要走日子格的。輸出格式輸出有一行,一個數(shù)表示走法數(shù)。那為了防止爆掉,我們每加完一條路的總步數(shù)之后就取一遍余。題目解法思路如上述,但是這里有一個我之前從來沒有注意過的問題,導致我一直只有分。三題解四題目鏈接過河馬 ...
摘要:更多的小算法練習,可以查看我的文章。規(guī)則使用語言,使用函數(shù)讀取,它將是一個字符串,指的是棋盤上點的位置。使用遞歸函數(shù)去解決,需要清楚判斷的臨界點,比如和時,只有一種選擇。 雖然都是很簡單的算法,每個都只需5分鐘左右,但寫起來總會遇到不同的小問題,希望大家能跟我一起每天進步一點點。更多的小算法練習,可以查看我的文章。 規(guī)則 Using the JavaScript language, h...
閱讀 3061·2023-04-26 02:27
閱讀 2773·2021-11-22 13:54
閱讀 910·2021-11-12 10:36
閱讀 3765·2021-10-09 09:44
閱讀 3188·2021-10-09 09:41
閱讀 1235·2021-09-22 10:02
閱讀 2845·2019-08-30 15:56
閱讀 3112·2019-08-30 11:02