当前位置: 首页 > wzjs >正文

彩票网站开发亿云网站引导页面设计

彩票网站开发亿云,网站引导页面设计,mvc做门户网站,wordpress模板网站LeetCode 热题 100_最小路径和(92_64) 题目描述:输入输出样例:题解:解题思路:思路一(多维动态规划): 代码实现代码实现(思路一(多维动态规划&…

LeetCode 热题 100_最小路径和(92_64)

    • 题目描述:
    • 输入输出样例:
    • 题解:
      • 解题思路:
        • 思路一(多维动态规划):
      • 代码实现
        • 代码实现(思路一(多维动态规划)):
        • 以思路一为例进行调试

题目描述:

给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。

**说明:**每次只能向下或者向右移动一步。

输入输出样例:

示例 1:
在这里插入图片描述

输入:grid = [[1,3,1],[1,5,1],[4,2,1]]
输出:7
解释:因为路径 1→3→1→1→1 的总和最小。

示例 2:
输入:grid = [[1,2,3],[4,5,6]]
输出:12

提示:
m== grid.length
n == grid[i].length
1 <= m, n <= 200
0 <= grid[i][j] <= 200

题解:

解题思路:

思路一(多维动态规划):

1、题目要求每次只能向下或者向右移动一步。则一个位置的元素可由左方和上方的位置移动而来。

  • dp[ i ][ j ]为路径上的数字总和最小。
  • dp[ i ][ j ] = min(dp[ i-1 ][ j ],dp[ i ][ j-1 ])+grid[ i ][ j ]。
  • dp[ 0 ][ 0 ] = grid[ 0 ][ 0 ]。
  • dp[ 0 ][ j ] = dp[ 0 ][ j-1 ]+grid[ 0 ][ j ]。第一行的元素只能由左侧元素移动得来。
  • dp[ i ][ 0 ] = dp[ i-1 ][ 0 ]+grid[ 0 ][ j ]。第一列的元素只能由上侧元素移动得来。

2、复杂度分析:
① 时间复杂度:O(mn),其中 m 和 n 分别是网格的行数和列数。需要对整个网格遍历一次,计算 dp 的每个元素的值。
② 空间复杂度:O(mn),其中 m 和 n 分别是网格的行数和列数。创建一个二维数组 dp,和网格大小相同(也可使用一维dp数组:参考LeetCode 热题 100_不同路径(91_62_中等_C++))。

代码实现

代码实现(思路一(多维动态规划)):
class Solution {
public:// 计算从左上角到右下角的最小路径和int minPathSum(vector<vector<int>>& grid) {// 创建一个dp数组,用于存储从起点到达每个格子的最小路径和vector<vector<int>> dp(grid.size(), vector<int>(grid[0].size()));// 初始化dp数组的起始位置,起点的路径和就是grid[0][0]的值dp[0][0] = grid[0][0];// 处理第一行,从左到右累加// 因为只能从左边的格子走到当前格子,所以每一行的第一个格子的路径和是累加的for (int j = 1; j < grid[0].size(); j++) {dp[0][j] = dp[0][j - 1] + grid[0][j];}// 处理第一列,从上到下累加// 因为只能从上方的格子走到当前格子,所以每一列的第一个格子的路径和是累加的for (int i = 1; i < grid.size(); i++) {dp[i][0] = dp[i - 1][0] + grid[i][0];}// 从(1, 1)开始,遍历整个grid// 每个格子的最小路径和是从它的上方格子或者左方格子中选择较小的路径和,再加上当前格子的值for (int i = 1; i < grid.size(); i++) {for (int j = 1; j < grid[0].size(); j++) {dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];}}// 返回右下角的最小路径和,即dp数组的右下角元素return dp[grid.size() - 1][grid[0].size() - 1];}
};
以思路一为例进行调试
#include<iostream>
#include<vector>
using namespace std;class Solution {
public:// 计算从左上角到右下角的最小路径和int minPathSum(vector<vector<int>>& grid) {// 创建一个dp数组,用于存储从起点到达每个格子的最小路径和vector<vector<int>> dp(grid.size(), vector<int>(grid[0].size()));// 初始化dp数组的起始位置,起点的路径和就是grid[0][0]的值dp[0][0] = grid[0][0];// 处理第一行,从左到右累加// 因为只能从左边的格子走到当前格子,所以每一行的第一个格子的路径和是累加的for (int j = 1; j < grid[0].size(); j++) {dp[0][j] = dp[0][j - 1] + grid[0][j];}// 处理第一列,从上到下累加// 因为只能从上方的格子走到当前格子,所以每一列的第一个格子的路径和是累加的for (int i = 1; i < grid.size(); i++) {dp[i][0] = dp[i - 1][0] + grid[i][0];}// 从(1, 1)开始,遍历整个grid// 每个格子的最小路径和是从它的上方格子或者左方格子中选择较小的路径和,再加上当前格子的值for (int i = 1; i < grid.size(); i++) {for (int j = 1; j < grid[0].size(); j++) {dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];}}// 返回右下角的最小路径和,即dp数组的右下角元素return dp[grid.size() - 1][grid[0].size() - 1];}
};int main(int argc, char const *argv[])
{vector<vector<int>> grid={{1,3,1},{1,5,1},{4,2,1}};Solution s;cout<<s.minPathSum(grid);return 0;
}

LeetCode 热题 100_最小路径和(92_64)原题链接
欢迎大家和我沟通交流(✿◠‿◠)

http://www.dtcms.com/wzjs/596671.html

相关文章:

  • 广州网站建设的公司长沙电商网站建设
  • 廊坊做网站公司企业商城网站 .net
  • 成都易站网站建设图片wordpress源码
  • 做网站是先做后台还是前端介绍重庆网页设计
  • 广州响应式网站南平seo
  • 有做公司网站的吗网站建设收费标准方案
  • 聊城网站建设北京十大影视后期公司
  • 钦州公司做网站网站开发毕设ppt
  • 大望路网站制作在线ps网页版
  • 传媒公司网站建设免费的个人简历模板网站
  • 手机网站优化指南东莞英文建站公司
  • 做网站策划案专业团队是什么意思
  • 安卓网站开发环境3gcms企业手机网站整站源码asp
  • 肥东网站制作华为官网手机商城
  • 用插件做的炫酷网站新余专业做淘宝网站
  • 企业网站开发期末报告上海中心设计公司是谁
  • 在线室内设计网站河南建设网站官网
  • 笔记本做网站微信小程序的制作流程
  • 想建立自己的网站怎么建立中职学校网站建设方案
  • 凉州区新农村建设网站做商业网站去哪里弄好
  • 深圳手机网站公司wordpress幻灯片回收站在哪里
  • 有什么做设计接任务的网站校园生活网页设计
  • 如何做律所网站网站首页快照应该怎么
  • 网站类型是什么意思商务网站建设实训心得体会
  • 网站栏目建设征求意见seo关键词推广话术
  • 分析杭州高端网站建设开发的区别千库网是什么
  • 九龙坡做网站崇信县门户网领导之窗
  • 中国建设劳动学会网站建立网站需要多少钱就蓷y湖南岚鸿推荐
  • 网站建设公司哪家最好wordpress百家号插件
  • 网站媒体作风建设年工作总结外贸建站 宁波