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

2024-05-14 22:04

本文主要是介绍强化训练: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;
}

总结

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

这篇关于强化训练:day8(求最小公倍数、数组中的最⻓连续⼦序列、字⺟收集)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/989971

相关文章

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的