/** * File: climbing_stairs_dfs.cs * Created Time: 2023-06-30 * Author: hpstory (hpstory1024@163.com) */ namespace hello_algo.chapter_dynamic_programming; public class climbing_stairs_dfs { /* 検索 */ int DFS(int i) { // dp[1] と dp[2] は既知なので返す if (i == 1 || i == 2) return i; // dp[i] = dp[i-1] + dp[i-2] int count = DFS(i - 1) + DFS(i - 2); return count; } /* 階段登り:探索 */ int ClimbingStairsDFS(int n) { return DFS(n); } [Test] public void Test() { int n = 9; int res = ClimbingStairsDFS(n); Console.WriteLine($"{n} 段の階段を上る方法は全部で {res} 通り"); } }