[蓝桥杯刷题]合并区间、最长不连续子序列、最长不重复数组长度

前言

在这里插入图片描述

⭐Hello!这里是欧_aita的博客。
⭐今日语录: 成功的关键在于对目标的持久追求。
⭐个人主页:欧_aita
ψ(._. )>⭐个人专栏:
数据结构与算法
数据库

在这里插入图片描述

在这里插入图片描述

文章目录

  • 前言
  • 合并区间问题📕
    • 现实应用
    • 大致思路
    • 代码实现
    • 代码讲解
  • 最长不连续子序列📕
    • 代码实现
      • 代码讲解
  • 滑动窗口求最长不重复子序列的长度📕
    • 大致思路
    • 代码实现

合并区间问题📕

现实应用

  • 合并重叠区间: 将给定的一组区间合并成尽可能少的不相交或相邻的区间。
  • 区间调度: 在一系列任务或活动中,每个任务有一个开始时间和结束时间,选择尽可能多的任务而不相互冲突。
  • 时间区间问题: 处理一系列时间区间,例如查找某个时间点同时发生的事件。
  • 日程安排: 对一组日程进行调度,以确定可以安排多少个活动而不冲突。

大致思路

在这里插入图片描述

代码实现

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;typedef pair<int, int> PII;const int N = 100010;int n;
vector<PII> segs;// 区间合并后的区间个数
// 1. 按区间左端点排序
// 2. 左端点st 右端点edvoid merge(vector<PII>& segs) {vector<PII> res;sort(segs.begin(), segs.end());int st = -2e9, ed = -2e9;for (auto seg : segs)if (ed < seg.first) {if (st != -2e9) res.push_back(make_pair(st, ed));st = seg.first, ed = seg.second;} elseed = max(ed, seg.second);if (st != -2e9) res.push_back(make_pair(st, ed));// 用合并后的区间更新原始向量segs = res;
}int main() {cin >> n;for (int i = 0; i < n; i++) {int l, r;cin >> l >> r;segs.push_back({l, r});}merge(segs);cout << segs.size() << endl;return 0;
}

代码讲解

sort(seg.begin(),seg.end());

这里的排序是通过vector数组中的pair数组中的first数据元素大小判断的。

在这里插入图片描述

最长不连续子序列📕

代码实现

#include <iostream>
#include <cstring>using namespace std;int main() {char str[1000];cout << "Enter a string: ";fgets(str, sizeof(str), stdin);int n = strlen(str);for (int i = 0; str[i]; i++) {int j = i;while (j < n && str[j] != ' ') {j++;}// 输出提取的单词for (int k = i; k < j; k++) {cout << str[k];}cout << endl;i = j;}return 0;
}

代码讲解

for (int i = 0; str[i]; i++) {int j = i;while (j < n && str[j] != ' ') {j++;}// 输出提取的单词for (int k = i; k < j; k++) {cout << str[k];}cout << endl;i = j;}

注意for循环的末端,将子序列的最后一个字符下标赋给了i,然后在for循环中i又+1就是下一个空格或者末端的位置

fgets(str, sizeof(str), stdin);:使用fgets函数从标准输入中读取用户输入的字符串,并存储到str数组中。sizeof(str)确保不会超出数组的边界。

滑动窗口求最长不重复子序列的长度📕

大致思路

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这个过程中不断计数,求取最长不重复数组长度。

代码实现

#include <iostream>
#include <cstring>using namespace std;const int N = 100010;int n;
int a[N], s[N];int main() {cin >> n;for (int i = 0; i < n; i++)cin >> a[i];int res = 0;for (int i = 0, j = 0; i < n; i++){s[a[i]]++;while(s[a[i]]>1){s[a[j]]--;j++;}res = max(res, i - j + 1);}cout << res << endl;return 0;
}

在这里插入图片描述

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

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

相关文章

jvisualvm手动安装VisualGC插件

前言 笔者近期排查问题需要查看GC的情况&#xff0c;于是用到了jvisualvm这个工具&#xff0c;查阅网上资料发现它有一个名为VisualGC的插件非常好用&#xff0c;于是笔者以此文记录一下VisualGC插件的安装步骤。 安装步骤 下载插件 首先我们要到官网 https://visualvm.gi…

未势能源受邀参加中国氢能100人论坛并发表演讲

12月12日-14日&#xff0c;“2023氢能嘉年华暨中国氢能100人论坛年会”在苏州举办&#xff0c;行业内专家学者、氢能头部企业代表等齐聚现场&#xff0c;聚焦氢能在化工、钢铁、交通等领域发展&#xff0c;共同探讨我国氢能产业初期前进之路。 未势能源液氢总工程师黄欢明受邀…

Java发起post和get请求

本文分享两种方式&#xff0c;一种是使用HttpURLConnection &#xff0c;另一种是使用 Apache HttpClient 使用 HttpURLConnection 发送 GET 请求&#xff1a; import java.net.HttpURLConnection; import java.net.URL; import java.io.BufferedReader; import java.io.Inpu…

DevOps搭建(六)-安装Maven详细步骤

1、官网下载 下载地址&#xff1a; Maven – Download Apache Maven 2、上传压缩包到服务器 把下载好的压缩包上传到服务器上。 3、解压压缩包 解压压缩包到安装目录/usr/local/ tar -zxvf apache-maven-3.9.3-bin.tar.gz -C /usr/local/ 切换到/usr/local目录下ls命令看…

基于FPGA的视频接口之高速IO(光纤)

简介 对于高速IO口配置光纤,现在目前大部分开发板都有配置,且也有说明,在此根据自己的工作经验以及对于各开发板的说明归纳 通过高速IO接口,以及硬件配置,可以实现对于光纤的收发功能,由于GTX的速率在500Mbs到10Gbps之间,但通道高速io可配置光纤10G硬件,物理通完成,则…

SpringIOC之Jsr330ScopeMetadataResolver

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

科东软件Intewell操作系统:以“鸿”鹄之志,创未来之“道”

打造自主可控的新型工业操作系统是我国加速新型工业化进程&#xff0c;在新一轮科技革命中实现“换道超车”的重要契机。科东软件期待凭借鸿道Intewell新型工业操作系统的创新与应用&#xff0c;打造100%自主可控的工业网络和工业控制底层技术&#xff0c;为我国新型工业化贡献…

顶级Web应用程序测试工具列表

今天主要列举Web应用程序的工具。 今天的列表仅仅提供索引功能&#xff0c;具体要使用的同学&#xff0c;可以自行搜索哦。 通过web应用程序测试&#xff0c;在web应用程序公开发布之前&#xff0c;会发现网站功能、安全性、可访问性、可用性、兼容性和性能等问题。 Web应用程…

JavaScript运算符 operator 操作符:

运算符对一个值或多个值进行运算 - 通过运算符可以对一个或多个值进行各种运算 - 大部分的运算符并不会影响到原来的变量 - 算术运算符 - 算术运算符可以用来对两个值进行算术运算 - 用来计算符号两侧值的和 - - 用来计算符号两侧值的差 - * 乘法 - / 除法 - ** 幂运…

JavaScript 数组常用的方法(删除数组中的某个值)二

删除数组中的某个值 splice() 方法&#xff1a;该方法可用于删除数组中的一项或多项&#xff0c;并返回删除的项。splice() 方法接受两个参数&#xff0c;第一个参数是要删除的起始位置&#xff0c;第二个参数是要删除的项数。 注意&#xff1a; splice() 方法会修改原始数组&…

模板方法模式(行为型)

目录 一、前言 二、模板模式 三、带钩子的模板模式 四、总结 一、前言 模板方法模式是一种行为型设计模式&#xff0c;它定义了一个操作中的算法框架&#xff0c;将一些步骤延迟到子类中实现。这种模式是基于“开闭原则”的设计思想&#xff0c;即对扩展开放&#xff0c;对…

JAVA:乘除窗体的实现

目录 题目要求&#xff1a; 窗口的实现&#xff1a; try 和 catch 的用法&#xff1a; 思路大意&#xff1a; 关键代码的实现&#xff1a; 题目要求&#xff1a; 使用 try 和catch 方法完成乘法除法的异常处理和窗体的实现&#xff0c;如下图所示&#xff1a; 窗口的实…

西瓜视频RenderThread引起的闪退问题攻坚历程

背景 影响 西瓜之前存在过一类RenderThread闪退&#xff0c;从堆栈上看&#xff0c;全部都是系统so调用&#xff0c;给人的第一印象像是一个系统bug&#xff0c;无从下手。闪退集中在Android 5~6上&#xff0c;表现为打开直播间立即闪退。该问题在2022年占据Native Crash Top5&…

Linux(19):基础系统设定与备份策略

系统基本设定 网络设定&#xff08;手动设定与 DHCP 自动取得&#xff09; 通常网络参数的取得方式常见的有底下这几种&#xff1a; 1.手动设定固定 IP 常见于学术网络的服务器设定、公司行号内的特定座位等。这种方式你必须要取得底下的几个参数才能够让你的 Linux 上网的: …

SpringBoot基础使用及对其他项目进行整合

目录 一、简介 1-讲述 2-特点 二、创建配置 1.创建 2.配置 3.代码生成 三、项目整合 每篇一获 一、简介 1-讲述 众所周知 Spring 应用需要进行大量的配置&#xff0c;各种 XML 配置和注解配置让人眼花缭乱&#xff0c;且极容易出错&#xff0c;因此 Spring 一度被称…

i春秋云镜之Initial

首先拿到目标IP&#xff1a;39.99.156.72 通过Fscan进行扫描发现存在Thinkphp RCE漏洞。 ./fscan_amd64 -h 39.99.156.72然后通过利用工具进行RCE。 我们进行getshell之后通过蚁剑进行连接。 反弹shell并转换成python 交互式shell。 rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/b…

《儿童绘本》期刊杂志发表论文投稿

《儿童绘本》杂志是由国家新闻出版管理部门批准&#xff0c;由吉林省舆林报刊发展有限责任公司主管主办&#xff0c;国内外公开发行的全国优秀期刊。办刊宗旨&#xff1a;以“普及绘本知识、推动儿童阅读”为理念&#xff0c;带动家庭亲子阅读&#xff0c;推动阅读教育及图画书…

nginx 配置SSE

使用SSE实现聊天功能&#xff0c;本地开发响应速度流畅&#xff0c;但打包部署后&#xff0c;聊天响应有卡顿现象。 前端页面部署在nginx中&#xff0c;在配置中添加以下SSE配置项 # SSE supportproxy_buffering off;proxy_cache off;proxy_read_timeout 86400s;proxy_send_tim…

C语言刷题数组------数组交换

输入一个长度为 10的整数数组 X[10]&#xff0c;将里面的非正整数全部替换为 1&#xff0c;输出替换完成后的数组。 输入格式 输入包含 10个整数&#xff0c;每个整数占一行。输出格式 输出新数组中的所有元素&#xff0c;每个元素占一行。输出格式为 X[i] x&#xff0c;其中…

Temporal 常见 FQ 速查

1、启动 worker 失败 INFO No Lofigured for temporal client. Created default one. Unable to create client failed reaching server: upstream connect error or disconnect/reset before headers. reset reason: connection failure 解决&#xff1a;没找到链接资源&…