每日刷题——相遇、宝石(模拟+数学)、相助(模拟+数组)、相依(dp的优化)

2024-06-01 15:20

本文主要是介绍每日刷题——相遇、宝石(模拟+数学)、相助(模拟+数组)、相依(dp的优化),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

相遇

原题链接登录—专业IT笔试面试备考平台_牛客网

题目描述

运行代码

#include<iostream>
using namespace std;
int main(){
int a,b;
cin>>a>>b;
if(a==b)
{ cout<<"p";
} 
else if(a - b == 1 || (a == 1 && b == 3)){cout << "b";}
else 
{cout<<"a";
}return 0;    
}

代码思路

分析输赢情况,总结输出结果即可

宝石(模拟+数学)

原题链接登录—专业IT笔试面试备考平台_牛客网

题目描述

 

运行代码

#include<iostream>
#include<string.h>
using namespace std;
int main(){
int a,b,c;
cin>>a>>b;
if(b<=2*a)
{
c=5*b+a;
}
else 
{c=11*a;
} cout<<c<<endl;return 0;
}

代码思路

数学情况总结,观察路段最短路线

相助(模拟+数组)

原题链接登录—专业IT笔试面试备考平台_牛客网

题目描述

运行代码

#include<iostream>
using namespace std;
const int N = 5e5+10;
int a[N];
int main()
{int n;cin>>n;for(int i=1;i<=n;i++){cin>>a[i];}if(n==1){cout<<"-1"<<endl;return 0;}if(a[1]==a[n]){cout<<1<<endl;return 0;}for(int i=2;i<n-1;i++){if(a[1]==a[i]&&a[i+1]==a[n]){cout<<"2"<<endl;return 0;}}cout<<-1;return 0;
}

代码思路

对给定的数据进行遍历查找,尝试找到两个相邻的相同元素,然后删除这两个元素。代码首先检查首尾两个元素是否相等,若相等则输出2即可;接着从第二个元素开始遍历,寻找与首尾相同的元素,若找到则输出2;如果没有找到任何符合条件的组合,则输出-1。

相依(dp的优化)

原题链接:登录—专业IT笔试面试备考平台_牛客网

题目描述

 

运行代码

#include <iostream>
#include<vector>
using namespace std;
int main() {ios::sync_with_stdio(false);cin.tie(nullptr);	int t = 1;while (t--) {int n;cin >> n;vector<int> a(n + 1);for (int i = 1; i <= n; i++) {cin >> a[i];}vector<int> dp(n + 1, -1);vector<int> st(n + 1, -1);	dp[0] = 0;st[a[1]] = 1;for (int i = 2; i <= n; i++) {int x = st[a[i]];if (x != -1 && dp[x - 1] != -1) {dp[i] = dp[x - 1] + 1;			if (dp[i - 1] != -1 && dp[i - 1] < dp[x - 1]) {st[a[i]] = i;}} else {st[a[i]] = i;}}	cout << dp[n] << "\n";}	return 0;
}

代码思路

通过动态规划来求解最小的操作次数。首先,代码定义了一个名为dp的向量,用来存储每个位置上的最小操作次数。同时,还有一个名为st的向量,用来记录每个元素最近被删除的位置。st向量的值为-1表示该元素尚未被删除。

接下来,代码从第二个元素开始遍历整个数组。在遍历过程中,代码会比较当前位置的元素与之前元素的值,如果相等,说明可以通过删除一段区间内的元素来使数组变为空。此时,代码会更新dp向量,并将当前元素的索引存入st向量中。

需要注意的是,在遍历过程中,代码还会检查当前元素的前一个元素是否比当前元素的最小操作次数少。如果是的话,代码会更新st向量,以便反映新的最小操作次数。

最后,代码输出dp[n],即数组变为零的最小操作次数。如果无法使数组变为零,dp[n]的值将会是-1。

这篇关于每日刷题——相遇、宝石(模拟+数学)、相助(模拟+数组)、相依(dp的优化)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

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

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

SpringBoot中HTTP连接池的配置与优化

《SpringBoot中HTTP连接池的配置与优化》这篇文章主要为大家详细介绍了SpringBoot中HTTP连接池的配置与优化的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、HTTP连接池的核心价值二、Spring Boot集成方案方案1:Apache HttpCl

PyTorch高级特性与性能优化方式

《PyTorch高级特性与性能优化方式》:本文主要介绍PyTorch高级特性与性能优化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、自动化机制1.自动微分机制2.动态计算图二、性能优化1.内存管理2.GPU加速3.多GPU训练三、分布式训练1.分布式数据

MySQL中like模糊查询的优化方案

《MySQL中like模糊查询的优化方案》在MySQL中,like模糊查询是一种常用的查询方式,但在某些情况下可能会导致性能问题,本文将介绍八种优化MySQL中like模糊查询的方法,需要的朋友可以参... 目录1. 避免以通配符开头的查询2. 使用全文索引(Full-text Index)3. 使用前缀索

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

Java数组初始化的五种方式

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