算法学习012-不同路径 c++动态规划算法实现 中小学算法思维学习 信奥算法解析

目录

C++不同路径

一、题目要求

1、编程实现

2、输入输出

二、算法分析

三、程序编写

四、运行结果

五、考点分析

六、推荐资料


C++不同路径

一、题目要求

1、编程实现

一个机器人位于一个 m x n网格的左上角 (起始点在下图中标记为 "Start" )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 "Finish" )。

问总共有多少条不同的路径?

注:总的台阶数n在1到40之间

2、输入输出

**输入描述:**输入网络行列数m,n(1<=m,n<=100)

**输出描述:**只有一行,一个整数,即从开始到结束有多少条不同路径

输入样例:

复制代码
3 7

28

输出样例:

复制代码
7

二、算法分析

  1. 从给定题目的初步分析可以看出,本题是问有多少种不同的路径可以到达
  2. 而且题目已经规定只能是向左和向下走,实现的方法有多种
  3. 这里采用动态规划的方式实现
  4. 可以设置动态数组dp[i][j],i和j表示对应网络的行和列号;所以对应的dp[i][j]就是从起始位置到达第i行和第j列所在网络有多少种方法
  5. 而能够到达第i行j列所在网格有两种方法:一种是从上一行往下走到达,即第i-1行j列到达,对应的路径数就是dp[i-1][j];另一种就是从左一列往右走到达,即第i行j-1列到达,对应的路径数就是dp[i][j-1]
  6. 所以可以得出对应的动态数组dp[i][j]的状态转移方为:dp[i][j]=dp[i-1][j]+dp[i][j-1]
  7. 而由于每一个网格都是从上或者从左到达的,所以初始的时候需要将第一行和第一列进行初始化,而第一行的值和第一列的值应该都是只有一种方法到达,所以都是1

三、程序编写

cpp 复制代码
//程序中的dp和cost数组可以使用动态数组vector进行实现更好
#include<bits/stdc++.h>
using namespace std;
int dp[102][102];
int getPaths(int m,int n)
{
	for(int i=0;i<m;i++)
		dp[i][0] = 1;
	for(int j=0;j<n;j++)
		dp[0][j] = 1;
	for(int i=1;i<m;i++)
		for(int j=1;j<n;j++)
			dp[i][j] = dp[i-1][j] + dp[i][j-1];
	return dp[m-1][n-1];
}
int main()
{
	int m,n;
	cin >> m >> n;
	cout << getPaths(m,n);
	return 0;
}

本文作者:小兔子编程 作者首页:小兔子编程-CSDN博客****

四、运行结果

cpp 复制代码
3 7

28

五、考点分析

难度级别:一般,这题相对而言在于最小花费,具体主要考查如下:

  1. 分析题目,找到解题思路
  2. 充分掌握变量和数组的定义和使用
  3. 学会动态规划算法的原理和使用
  4. 确定动态数组的定义和含义
  5. 分析出动态规划算法的状态转移方程以及遍历顺序
  6. 学会输入流对象cin的使用,从键盘读入相应的数据
  7. 学会for循环的使用,在确定循环次数的时候推荐使用学会
  8. 掌握输出流对象cout的使用,与流插入运算符 << 结合使用将对象输出到终端显示
  9. 学会分析题目,算法分析,将复杂问题模块化,简单化,从中找到相应的解题思路
  10. 充分掌握变量定义和使用、分支语句、循环语句和动态规划算法的应用

PS:方式方法有多种,小朋友们只要能够达到题目要求即可!

六、推荐资料

相关推荐
我想进大厂38 分钟前
图论---朴素Prim(稠密图)
数据结构·c++·算法·图论
我想进大厂43 分钟前
图论---Bellman-Ford算法
数据结构·c++·算法·图论
AIGC大时代1 小时前
高效使用DeepSeek对“情境+ 对象 +问题“型课题进行开题!
数据库·人工智能·算法·aigc·智能写作·deepseek
CODE_RabbitV1 小时前
【深度强化学习 DRL 快速实践】近端策略优化 (PPO)
算法
Wendy_robot2 小时前
【滑动窗口+哈希表/数组记录】Leetcode 438. 找到字符串中所有字母异位词
c++·算法·leetcode
程序员-King.2 小时前
day49—双指针+贪心—验证回文串(LeetCode-680)
算法·leetcode·贪心算法·双指针
转基因3 小时前
Codeforces Round 1020 (Div. 3)(题解ABCDEF)
数据结构·c++·算法
我想进大厂4 小时前
图论---Kruskal(稀疏图)
数据结构·c++·算法·图论
@Aurora.4 小时前
数据结构手撕--【二叉树】
数据结构·算法
victd4 小时前
什么是AutoRec?
算法