算法学习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:方式方法有多种,小朋友们只要能够达到题目要求即可!

六、推荐资料

相关推荐
南城花随雪。5 分钟前
单片机:实现FFT快速傅里叶变换算法(附带源码)
单片机·嵌入式硬件·算法
dundunmm21 分钟前
机器学习之scikit-learn(简称 sklearn)
python·算法·机器学习·scikit-learn·sklearn·分类算法
古希腊掌管学习的神21 分钟前
[机器学习]sklearn入门指南(1)
人工智能·python·算法·机器学习·sklearn
波音彬要多做22 分钟前
41 stack类与queue类
开发语言·数据结构·c++·学习·算法
程序员老冯头2 小时前
第十五章 C++ 数组
开发语言·c++·算法
AC使者7 小时前
5820 丰富的周日生活
数据结构·算法
cwj&xyp7 小时前
Python(二)str、list、tuple、dict、set
前端·python·算法
xiaoshiguang312 小时前
LeetCode:222.完全二叉树节点的数量
算法·leetcode
爱吃西瓜的小菜鸡12 小时前
【C语言】判断回文
c语言·学习·算法
别NULL12 小时前
机试题——疯长的草
数据结构·c++·算法