您的位置:首页 > 游戏 > 游戏 > 长春网络推广优化_装饰公司网站模板_西安seo建站_宁波seo网站服务

长春网络推广优化_装饰公司网站模板_西安seo建站_宁波seo网站服务

2024/12/26 22:40:11 来源:https://blog.csdn.net/kitesxian/article/details/144219956  浏览:    关键词:长春网络推广优化_装饰公司网站模板_西安seo建站_宁波seo网站服务
长春网络推广优化_装饰公司网站模板_西安seo建站_宁波seo网站服务

链接

我的代码:

class Solution {
public:int uniquePaths(int m, int n) {if(m<=1||n<=1)return 1;vector<vector<int>> dp(m,vector<int>(n));for(int i = 0;i<m;i++){for(int j = 0;j<n;j++){if(!i&&!j)dp[i][j] = 0;else if(!i||!j)dp[i][j] = 1;else dp[i][j] = dp[i-1][j]+dp[i][j-1];}}return dp[m-1][n-1];}
};

空间优化为O(N):
 

class Solution {
public:int uniquePaths(int m, int n) {vector<int> f(n,1);for(int i = 1;i<m;i++){for(int j = 1;j<n;j++){f[j] +=f[j-1];}}return f[n-1];}
};//空间O(N),时间O(m*n)
// 动态规划数组f:
// 使用一维数组 f 来存储每一列的路径数。数组大小为 n,表示当前行的路径数。
// 初始化 f 为 1,表示从起点 (0, 0) 到达任意第一行或第一列的路径数都是 1(因为只能直走)。
// 循环更新路径数:
// 外层循环 for (int i = 1; i < m; i++) 遍历每一行,从第二行开始,因为第一行已经初始化。
// 内层循环 for (int j = 1; j < n; j++) 遍历每一列,从第二列开始。
// f[j] = f[j] + f[j - 1]; 这行代码的核心逻辑:
// f[j] 表示到达位置 (i, j) 的路径数。
// 这个值是由上方位置 (i-1, j) 的路径数(即 f[j])和左侧位置 (i, j-1) 的路径数(即 f[j-1])相加得来的。
// 因此,f[j] 更新为当前格子路径数的总和。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com