蓝桥杯_day6

文章目录

    • 不同路径
    • 不同路径II
    • 拿金币
    • 珠宝的最高价值

不同路径

【题目描述】
一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。
问总共有多少条不同的路径?

【输入样例】

m=3 n=7

【输出样例】

28

【数据规模与约定】

  • 1 <= m, n <= 100
  • 题目数据保证答案小于等于 2 * 109

【解题思路】
创建一个二维的dp表,
通过题目我们可以得出,dp[i][j]的值表示的是到达当前位置一共有多少条不同的路径。
在初始化的时候,因为题目限制在走动的时候只能往右或者往下,不能回退,所以我们会发现第一行和第一列都是1,在初始化的时候可以先将第一行以及第一列都初始化为1.

【C++程序代码】
方法一:初始化一行一列

class Solution {
public:int uniquePaths(int m, int n) {vector<vector<int>> dp(m, vector<int>(n));dp[0][0] = 1;for (int i = 1; i < m; i++){dp[i][0] = 1;}for (int i = 1; i < n; i++){dp[0][i] = 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];}
};

方法二:创建虚拟一行一列

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

不同路径II

【题目描述】
一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。
机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”)。

现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?
网格中的障碍物和空位置分别用 10 来表示。

【输入样例】

obstacleGrid = [[0,0,0],[0,1,0],[0,0,0]]

【输出样例】

2

【数据规模与约定】

  • m == obstacleGrid.length
  • n == obstacleGrid[i].length
  • 1 <= m, n <= 100
  • obstacleGrid[i][j]01

【解题思路】
创建一个二维的dp表,
通过题目我们可以得出,dp[i][j]的值表示的是到达当前位置一共有多少条不同的路径。
在初始化的时候,因为题目限制在走动的时候只能往右或者往下,不能回退,所以我们会发现第一行和第一列都是1,在初始化的时候可以先将第一行以及第一列都初始化为1.

【C++程序代码】

class Solution {
public:int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {int row = obstacleGrid.size() + 1;int col = obstacleGrid[0].size() + 1;vector<vector<int>> dp(row, vector<int>(col));dp[0][1] = 1;for (int i = 1; i < row; i++){for (int j = 1; j < col; j++){if (obstacleGrid[i - 1][j - 1] != 1){dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}}return dp[row - 1][col - 1];}
};

拿金币

【题目描述】
有一个N x N的方格,每一个格子都有一些金币,只要站在格子里就能拿到里面的金币。你站在最左上角的格子里,每次可以从一个格子走到它右边或下边的格子里。请问如何走才能拿到最多的金币。

【输入格式】
第一行输入一个正整数n。
以下n行描述该方格。金币数保证是不超过1000的正整数。

【输出格式】
最多能拿金币数量。

【输入样例】

3  
1 3 3  
2 2 2  
3 1 2

【输出样例】

11

【数据规模与约定】

  • n<=1000

【解题思路】
每经过一个格子对这个位置的左侧和上面进行比较,选择大的金币数量和当前所处于的格子的金币数量进行相加。

【C++程序代码】

#include<bits/stdc++.h>
using namespace std;int main()
{int n;cin >> n;vector<vector<int>> s(n, vector<int>(n));for (int i = 0; i < n; i++){for (int j = 0; j < n; j++){cin >> s[i][j];}}vector<vector<int>> dp(n+1, vector<int>(n+1));for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){dp[i][j] = max(dp[i][j - 1], dp[i - 1][j]) + s[i - 1][j - 1];}}return 0;
}

珠宝的最高价值

【题目描述】
现有一个记作二维矩阵 frame 的珠宝架,其中 frame[i][j] 为该位置珠宝的价值。拿取珠宝的规则为:

  • 只能从架子的左上角开始拿珠宝
  • 每次可以移动到右侧或下侧的相邻位置
  • 到达珠宝架子的右下角时,停止拿取
    注意:珠宝的价值都是大于 0 的。除非这个架子上没有任何珠宝,比如 frame = [[0]]

【输入样例】

frame = [[1,3,1],[1,5,1],[4,2,1]]

【输出样例】

12

【数据规模与约定】

  • 0 < frame.length <= 200
  • 0 < frame[0].length <= 200

【解题思路】
这一题基本与上题相同。
每经过一个格子对这个位置的左侧和上面进行比较,选择大的珠宝价格和当前所处于的格子的珠宝价格进行相加。

【C++程序代码】

class Solution {
public:int jewelleryValue(vector<vector<int>>& frame) {int row = frame.size();int col = frame[0].size();vector<vector<int> > dp(row + 1, vector<int>(col + 1));for (int i = 1; i <= row; i++){for (int j = 1; j <= col; j++){dp[i][j] = max(dp[i][j - 1], dp[i - 1][j]) + frame[i - 1][j - 1];}}return dp[row][col];}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/777855.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

十一、Spring源码学习之registerListeners方法

registerListeners()方法 protected void registerListeners() {// Register statically specified listeners first.//获取容器中事件监听并存放到多播器中 applicationListenersfor (ApplicationListener<?> listener : getApplicationListeners()) {getApplicationE…

Flutter——用户关闭键盘后强制拉起键盘

Bug背景 今天在弄输入框的时候&#xff0c;发现用户手动关闭键盘后&#xff0c;因为自定义组件的特殊性&#xff0c;我在点击输入框后并没有唤起键盘。 一般点击输入框或者某个组件&#xff1a; GestureDetector(onTap: () {FocusScope.of(context).requestFocus(_focusNode…

解决element ui中的el-tree组件default-checked-keys默认勾选节点问题

解决element ui中的el-tree组件default-checked-keys默认勾选节点问题 需求解决方法方法1方法2 需求 选中子节点的时候&#xff0c;父节点必须被选中&#xff0c;但是仅展示被选中父节点和子节点 解决方法 方法1 html部分代码&#xff1a; <el-treeclass"filter-tr…

【I.MX6ULL移植】Ubuntu-base根文件系统移植

1.下载Ubuntu16.04根文件系统 http://cdimage.ubuntu.com/ 1 2 3 4 5 2.解压ubuntu base 根文件系统 为了存放 ubuntu base 根文件系统&#xff0c;先在 PC 的 Ubuntu 系统中的 nfs 目录下创建一个名为 ubuntu_rootfs 的目录&#xff0c;命令如下&#xff1a; 【注意&…

基于单片机病房呼叫系统数码管显示房号设计

**单片机设计介绍&#xff0c;基于单片机病房呼叫系统数码管显示房号设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机病房呼叫系统数码管显示房号设计概要主要涵盖了利用单片机技术实现病房呼叫系统&#xff0c;并…

mac上查看以及修改DNS配置

前言 特殊场景下&#xff0c;我们可能需要本机上的DNS配置 操作步骤 查看 mac上的 已有的dns配置# 如果你使用的是以太网连接&#xff0c;将命令中的 "Wi-Fi" 替换为 "Ethernet"。 networksetup -getdnsservers Wi-Fi修改DNS配置# DNS_SERVER_IP_ADDRES…

WPF 多路绑定、值转换器ValueConvert、数据校验

值转换器 valueconvert 使用ValueConverter需要实现IValueConverter接口&#xff0c;其内部有两个方法&#xff0c;Convert和ConvertBack。我们在使用Binding绑定数据的时候&#xff0c;当遇到源属性和目标控件需要的类型不一致的&#xff0c;就可以使用ValueConverter&#xf…

GT收发器第一篇_总体结构介绍

文章目录 前言GT收发器介绍 前言 之前写过一篇简单介绍GT的文章https://blog.csdn.net/m0_56222647/article/details/136730026&#xff0c;可以先通过这篇文章对整体进行简单了解一下。 GT收发器介绍 参考xilinx手册ug476 对于7系列的FPGA&#xff0c;共有3个系列&#xf…

【MATLAB源码-第19期】matlab基于导频的OFDM系统瑞利信道rayleigh的信道估计仿真,输出估计与未估计误码率对比图。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 正交频分复用&#xff08;英语&#xff1a;Orthogonal frequency-division multiplexing, OFDM&#xff09;有时又称为分离复频调制技术&#xff08;英语&#xff1a;discrete multitone modulation, DMT&#xff09;&#x…

数据仓库——事务、快照和累积快照事实表

事务、快照和累积快照 事务事实表跟踪定义业务过程的个体行为&#xff0c;并且支持几种描述这种行为事实。可以提供丰富的分析型能力&#xff0c;时常充当原子数据的粒度化仓库快照事实表周期性地采样状态度量&#xff0c;这些度量与一系列事务的累积效果相当&#xff0c;但是…

Android和IOS应用开发-Flutter应用让屏幕在 app 运行期间保持常亮的方法

文章目录 Flutter应用让屏幕在 app 运行期间保持常亮的方法方法一&#xff1a;使用系统插件方法二&#xff1a;使用 Widgets注意事项 Flutter应用让屏幕在 app 运行期间保持常亮的方法 在 Flutter 开发中&#xff0c;可以使用以下两种方法让屏幕在 app 运行期间保持常亮&#…

【数据库监控系列】Prometheus+Alertmanager+Grafana容器化部署

【数据库监控系列】PrometheusAlertmanagerGrafana容器化部署 快速安装docker环境被监控端部署exporter配置Redis exporter配置MySQL exporter 部署Prometheus和GrafanaPrometheus配置文件Alertmanager配置文件rule_files告警规则文件docker-compose部署文件常见报错信息 配置G…

【MySQL】6.MySQL主从复制和读写分离

主从复制 主从复制与读写分离 通常数据库的读/写都在同一个数据库服务器中进行&#xff1b; 但这样在安全性、高可用性和高并发等各个方面无法满足生产环境的实际需求&#xff1b; 因此&#xff0c;通过主从复制的方式同步数据&#xff0c;再通过读写分离提升数据库的并发负载…

Rabbitmq消息堆积的问题以及解决方案

1.消息堆积的原因&#xff1a; 短时间内出现了大量的数据涌入 消费速度慢 2.解决方案 2.1 预防措施&#xff1a; 生产者&#xff1a; 减少发布频率&#xff0c;考虑使用队列最大长度限制&#xff0c;尽可能保证消息都可以被接收。 消费者&#xff1a; 增加消费者的处理能力…

八大技术趋势案例(区块链量子计算)

科技巨变,未来已来,八大技术趋势引领数字化时代。信息技术的迅猛发展,深刻改变了我们的生活、工作和生产方式。人工智能、物联网、云计算、大数据、虚拟现实、增强现实、区块链、量子计算等新兴技术在各行各业得到广泛应用,为各个领域带来了新的活力和变革。 为了更好地了解…

百度智能云千帆,产业创新新引擎

本文整理自 3 月 21 日百度副总裁谢广军的主题演讲《百度智能云千帆&#xff0c;产业创新新引擎》。 各位领导、来宾、媒体朋友们&#xff0c;大家上午好。很高兴今天在石景山首钢园&#xff0c;和大家一起沟通和探讨大模型的发展趋势&#xff0c;以及百度最近一段时间的思考和…

halcon目标检测标注保存

* 创建一个新的字典 create_dict(ObjectDictionary) * 类别名称列表和对应的ID列表 class_names : [Defect1,Defect2,Defect3,Defect4,Defect5,Defect6,Defect7,Defect8,Defect9,Defect10,Defect11,Defect12,Defect13,Defect14,Defect15,Defect16,Defect17,Defect18] class_id…

jmockit-01-test 之 jmockit 入门使用案例

拓展阅读 jmockit-01-jmockit 入门使用案例 jmockit-02-概览 jmockit-03-Mocking 模拟 jmockit-04-Faking 伪造 jmockit-05-代码覆盖率 mockito-01-入门介绍 mockito-02-springaop 整合遇到的问题&#xff0c;失效 jmockit 说明 jmockit 可以提供基于 mock 的测试能力…

移动端开发思考:Uniapp的上位替代选择

文章目录 前言跨平台开发技术需求技术选型uniappFlutterMAUIAvalonia安卓原生 Flutter开发尝试Avalonia开发测试测试项目新建项目代码MainViewMainViewModel 发布/存档 MAUI实战&#xff0c;简单略过打包和Avalonia差不多 总结 前言 作为C# .NET程序员&#xff0c;我有一些移动…

前端基础复习--HTML篇

html: html文件根标签 head&#xff1a;编写页面相关的属性 title&#xff1a;页面标题 body&#xff1a;页面内容展示信息 标题标签&#xff1a;h1 - h6&#xff0c;数字越大&#xff0c;字体越小 &#xff0c;例如&#xff1a; <h1>hello</h1> p标签&#x…