强化训练:day8(求最小公倍数、数组中的最⻓连续⼦序列、字⺟收集)

文章目录

  • 前言
  • 1. 最小公倍数
    • 1.1 题目描述
    • 1.2 解题思路
    • 1.3 代码实现
  • 2. 数组中的最⻓连续⼦序列
    • 2.1 题目描述
    • 2.2 解题思路
    • 2.3 代码实现
  • 3. 字母收集
    • 3.1 题目描述
    • 3.2 解题思路
    • 3.3 代码实现
  • 总结

前言

  1. 最小公倍数
  2. 数组中的最⻓连续⼦序列
  3. 字⺟收集

1. 最小公倍数

1.1 题目描述

在这里插入图片描述

1.2 解题思路

  最小公倍数= A * B / 最大公约数(数学中的短除法),最大公约数:辗转相除法。

1.3 代码实现

#include <iostream>
using namespace std;
using ll = long long;
// 求最大公约数 -> 辗转相除法
ll solve(ll x, ll y) 
{ll ret = 0;while (x % y != 0) {ret = x % y;x = y;y = ret;}return y;
}
int main() 
{ll x, y;cin >> x >> y;ll num = solve(max(x, y), min(x, y));// 短除法ll ret = (x / num) * (y / num) * num;cout << ret;return 0;
}

2. 数组中的最⻓连续⼦序列

2.1 题目描述

在这里插入图片描述

2.2 解题思路

  排序 + 模拟,我们要找的是最长的连续子序列,题目明确说了,只要求值连续,不要求位置连续,因此可以进行排序来帮助我们进行解题。
  排序之后就是从小到大排列,那么问题就简单,我们一次枚举一遍,看看当前值和前一个值的大小是不是相差为1即可,符合条件就将我们的计算count++,不符合就从当前位置开始下一次的判断。不过需要注意的是重复数字的问题,因为对于重复数字还需要进行判断,只需要将我们的标记指针向后移动,计算count不变就可以了。
  我一开始就没有考虑到重复数字的问题,导致没写出来……

2.3 代码实现

class Solution {public:// 注意处理数据重复的问题!!!!!!!using ll = long long;int MLS(vector<int>& arr) {int n = arr.size();sort(arr.begin(), arr.end());int left = 0;int len = 0;while (left < n) {int right = left + 1;int count = 1;while(right < n){if(arr[right] - arr[right - 1] == 1) {right++;count++;}else if(arr[right] - arr[right - 1] == 0){right++;}else{break;}}len = max(len, count);left = right;}return len;}
};

3. 字母收集

3.1 题目描述

在这里插入图片描述

3.2 解题思路

  简单的路径dp问题,我们可以根据题目描述来设置状态,设置一个二维的dp数组,dp[i][j]表示到达 [ i ,j ] 位置最多能获得多少分。而每一个位置的分数与两个位置有关,那就是二维数组中当前位置的上方的数据和左边的数据。
  那么状态转移方程就是:dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) + add(grid[i - 1][j - 1]); 继续来解释一下,先说add函数,它是用来表示 i,j 位置的字符所得的分数,至于为什么要减1,一会说。我们现在知道了当前位置所能获得的最大分数来自于两个方向,我们肯定需要取大的一个,所以用max,取到大的分数之后,还需要加上当前位置的字母的分数,才是到达当前位置所能获得的最大分数。
  至于为什么减1,则是因为,我们来第一个位置的,它需要它的上面的和左边的数据,但是这是会越界的,所以我们可以将dp表多开一行一列,来避免越界问题。比如,字母的位置是0 0(也就是第一个字符),那么它在dp表中的位置就是1 1,这样就可以避免越界问题了。但是在统计字符分数,就需要进行减一来找到原来的位置了。(不理解的可以画一个二维数组来看一下)

3.3 代码实现

#include <iostream>
using namespace std;
#include <vector>
#include <string>
#include <cstring>
int m, n;
int add(char s) 
{if (s == 'l') return 4;else if (s == 'o') return 3;else if (s == 'v') return 2;else if (s == 'e') return 1;else return 0;
}
int main() 
{cin >> m >> n;vector<vector<char>> grid(m, vector<char>(n));vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0));   for (int i = 0; i < m; i++)for(int j = 0; j < n; j++)cin >> grid[i][j];for (int i = 1; i <= m; i++)for (int j = 1; j <= n; j++) {dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) + add(grid[i - 1][j - 1]);}cout << dp[m][n];    return 0;
}

总结

  处理第一题,后面两个题还是有很多细节的地方要处理的,而且对于这种题,看题解可能一看就会了,一写就废了,原因就是有很多的边界问题以及条件判断并没有搞清楚或者说没有意识到,所以总是出错。而为了能避免这种情况,只能是多写,不能光看不写。
  那么第八天的内容就到此结束了,如果大家发现有什么错误的地方,可以私信或者评论区指出喔。我会继续坚持训练的,希望能与大家共同进步!!!那么本期就到此结束,让我们下期再见!!觉得不错可以点个赞以示鼓励!

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

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

相关文章

【数据可视化01】matplotlib实例介绍2

目录 一、引言二、实例介绍1.箱线图2.热力图3.3D图 一、引言 接着上一文章【数据可视化01】matplotlib实例介绍1继续介绍matplotlib的实例。 二、实例介绍 在matplotlib中&#xff0c;常用的图形类型包括&#xff1a; 箱线图&#xff08;Box plot&#xff09;&#xff1a;用…

[Java EE] 文件IO (二):文件内容读写-----数据流

&#x1f338;个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 &#x1f3f5;️热门专栏:&#x1f355; Collection与数据结构 (91平均质量分)https://blog.csdn.net/2301_80050796/category_12621348.html?spm1001.2014.3001.5482 &#x1f9c0;Java …

Seal^_^【送书活动第4期】——《Web渗透测试技术》

Seal^_^【送书活动第4期】——《Web渗透测试技术》 一、参与方式二、本期推荐图书2.1 前 言2.2 关于本书2.3 本书读者2.4 图书简介2.5 作者荐语2.6 编辑推荐2.7 目 录 三、正版购买 掌握Web渗透测试技术&#xff0c;提高Web应用安全性。 一、参与方式 1、关注博主的账号。 2、点…

Qt---项目的创建及运行

一、创建第一个Qt程序 1. 点击创建项目后&#xff0c;选择项目路径以及给项目起名称 名称&#xff1a;不能有中文、不能有空格 路径&#xff1a;不能有中文路径 2. 默认创建有窗口类myWidget&#xff0c;基类有三种选择&#xff1a;QWidget、QMainWindow、QDialog 3. m…

ssl证书免费申请指南

同学们可以私信我加入学习群&#xff01; 正文开始 前言一、购买证书二、创建证书三、 验证证书等待出现如下页面&#xff0c;说明申请成功&#xff1a; ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/6b6c1dd11d4c467687318552da7cdbb2.png) 总结 前言 今天为大…

企业必看:镭速教你如何测试内网文件传输效率和稳定问题

在现代商业运作中&#xff0c;企业内部文件传输的效率和稳定性对于数据管理和业务流程极为重要。无论是远程工作还是团队协作&#xff0c;高效的文件传输都能显著提升工作效率。今天镭速小编就教你如何测试内网文件传输效率和稳定问题。 1、磁盘性能&#xff0c;即硬盘的读取和…

类图及类的关系

类图&#xff08;Class Diagram&#xff09;是UML&#xff08;Unified Modeling Language&#xff0c;统一建模语言&#xff09;中的一种图&#xff0c;用于描述系统中类的静态结构&#xff0c;包括类的属性、方法以及类之间的关系。 一、类 类&#xff08;Class&#xff09;…

高级查询(一)

解决需求&#xff1a;Excel都可以轻松搞定 分组查询原理&#xff1a; 语法&#xff1a; SELECT …<列名> FROM <表名> [WHERE<条件表达式> ] GROUP BY 参与分组的列 可以与 聚合函数作用的列 一块显示 注意 SELECT列表中只能包含&#xff1a; 1、被分…

勒索软件漏洞?在不支付赎金的情况下解密文件

概述 在上一篇文章中&#xff0c;笔者对BianLian勒索软件进行了研究剖析&#xff0c;并且尝试模拟构建了一款针对BianLian勒索软件的解密工具&#xff0c;研究分析过程中&#xff0c;笔者感觉构建勒索软件的解密工具还挺有成就感&#xff0c;因此&#xff0c;笔者准备再找一款…

gin框架学习笔记(三) ——路由请求与相关参数

参数种类与参数处理 查询参数 在讲解查询参数的定义之前&#xff0c;我们先来看一个例子&#xff0c;当我打开了CSDN&#xff0c;我现在想查看我的博客浏览量&#xff0c;那么我就需要点击我的头像来打开我的个人主页,像下面这样: 我们现在把浏览器的网址取下来&#xff0c;…

uniapp编译H5解决ios的border-radius失效问题,以及ios满屏显示不全的问题

1.解决方案 .card-itemA {width: 650rpx;height: 326rpx;box-shadow: 0rpx 0rpx 30rpx 14rpx rgba(236, 235, 236, 0.25);background: linear-gradient(180deg, #FFFFFF 0%, rgba(255, 255, 255, 0) 100%);border-radius: 60rpx;overflow: hidden;// 兼容ios的圆角问题transfor…

web入门练手案例(一)

下面是一下web入门案例和实现的代码&#xff0c;带有部分注释&#xff0c;倘若代码中有任何问题或疑问&#xff0c;欢迎留言交流~ 新闻页面 案例描述&#xff1a; 互联网的发展使信息的传递变得方便、快捷&#xff0c;浏览新闻称为用户获取信息的重要渠道。下面将实现一个简…