牛客周赛 Round 74

D. 预知

题目链接
在这里插入图片描述
题意有点绕,简单来说是其中一堆牌,问最少预知几张才能保证任取两张都不会导致种类重复。一开始对每张牌种类不是已知的,已知的是每种牌的牌数。

思路就是相当于把其中一种明牌,保证任取两张都不会导致种类重复 的 最坏情况就是预知种类最多的张数。

  1. n = 1 时 显然无解。
  2. n >= 2时 若每种牌都只有一张,则无需操作,因为怎么抽都是不同的牌。
  3. 若数组次大值为1,则需要执行 max - 1次, 变成第二种情况
  4. 否则答案就是最大值,相当于把最多牌的数量给取完,最后任取其他。
    一开始尝试累加想复杂了, 这种情况应该累加 取max min 都试试 hhh。

#define ll long long

#include <bits/stdc++.h>

using namespace std;

const int N = 2e5 + 5;
	
int a[N];

int main(){
	ios::sync_with_stdio(false);
	int t;cin >> t;
	while(t--){
		int n;
		cin >> n;
		bool f = 1;
		
		for(int i = 0;i < n;i ++){
			cin >> a[i];
			if(a[i] != 1) f = 0;
		}
		
		if(n == 1){
			cout << -1 << '\n';
			continue;
		}
		if(f){
			cout << 0 << '\n';
			continue;
		}
		sort(a, a + n);
		
		ll res = 0;
		
		if(a[n - 2] == 1 && a[n - 1] != 1) res = a[n - 1] - 1;
		else res = a[n - 1];
		
		cout << res << '\n';
	}
	return 0;
}

E. 而后单调

在这里插入图片描述
题意是问是否存在从数组中选出长为m的子数组,将剩下的n-m进行排序后,将该子数组找一个位置插入后保持整个序列递增后递减

首先考虑数组不能有重复元素,因为重复无法保证严格单调,所以必然无解。
然后分成两种情况:1.严格单调递增 2.严格单调递减。
我们拿出的连续 m 个数必然是有序的,否则不符合题意。然后该段可以放进头部,中部,尾部,总结下来其实就是这段在原来的数组排序后也是一段连续的数字
因此我们复制一下数组后排序,得到排序后的数组,并且映射一下长为m的子数组的首尾元素,此时包含符合题目条件的所有情况。 然后去原数组中寻找是否存在该子数组,并判断是否单调。这里判断单调的方法也是O1的


#define ll long long

#include <bits/stdc++.h>

using namespace std;

map <int,int> mp;
map <int,int> to;

void solve(){
	int n,m;
	cin >> n >> m;
	vector <int> a(n+1);
	mp.clear();
	for(int i = 1;i <= n;i ++){
		cin >> a[i];
	}
	
	for(int i = 1;i <= n;i ++){
		if(mp[a[i]]){
			cout << "NO" << '\n';
			return ;
		}
		++ mp[a[i]];
	}
	
	vector <int> b(a);
	sort(b.begin() + 1, b.end());
	
	to.clear();
	for(int i = 1; i + m - 1 <= n;i ++){
		to[b[i]] = b[i + m -1];// 映射m段单调序列,每段(子数组)的段头元素为 b[i]和 段尾 b[i+m-1]
	}
	
	vector <int> pre(n + 5);
	for(int i = 1;i <= n;i ++){
		pre[i] = pre[i - 1] + (a[i] > a[i - 1]);
	}
	
	for(int i = 1;i + m - 1 <= n;i ++){
		if(pre[i+m-1] - pre[i] == m-1){// 当前段满足单调序列,即m个数有m-1次单调递增
			if(to[a[i]] == a[i+m-1]){ // 并且在原数组中,存在长为m的段, 和排序后的b对应
				cout << "YES" << '\n';
				return ;
			}
		}
	}
	
	//单调递减的情况同理
	vector <int> suf(n + 5);
	for(int i = n;i >= 1;i --){
		suf[i] = suf[i+1] + (a[i] > a[i+1]);
	}
	
	for(int i = 1;i + m - 1 <= n;i ++){
		if(suf[i] - suf[i+m-1] == m-1){
			if(to[a[i+m-1]] == a[i]){
				cout << "YES" << '\n';
				return ;
			}
		}
	}
	cout << "NO" << '\n';
}

int main(){
	ios::sync_with_stdio(false);
	int t;
	cin >> t;
	
	while(t--){
		solve();
	} 
	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【linux学习指南】SIGCHLD信号

文章目录 &#x1f4dd;SIGCHLD信号&#x1f6a9;总结 &#x1f4dd;SIGCHLD信号 进程⼀章讲过⽤wait和waitpid函数清理僵⼫进程,⽗进程可以阻塞等待⼦进程结束,也可以⾮阻塞地查询是否有⼦进程结束等待清理(也就是轮询的⽅式)。采⽤第⼀种⽅式,⽗进程阻塞了就不能处理⾃⼰的⼯…

AI助力SEO优化的关键词策略解析

内容概要 在数字营销的快速发展中&#xff0c;人工智能&#xff08;AI&#xff09;正逐步成为提升搜索引擎优化&#xff08;SEO&#xff09;效果的重要工具。关键词策略是SEO成功的关键要素之一&#xff0c;而AI技术的应用使得这一过程更加高效和精准。在关键词研究中&#xf…

PHP-Casbin v4.0.0 发布,支持 ACL、RBAC、ABAC 等模型的访问控制框架

PHP-Casbin 是一个用 PHP 语言打造的轻量级开源访问控制框架&#xff0c;支持 ACL、RBAC、ABAC 多种模型。它采用了元模型的设计思想&#xff0c;支持多种经典的访问控制方案&#xff0c;如基于角色的访问控制 RBAC、基于属性的访问控制 ABAC 等。 更新内容&#xff1a; http…

解决Git中没有小绿勾与红叉叉的问题

一、检查自己的软件 必须安装Git和Tortoisegit&#xff08;也就是俗称的小乌龟&#xff09;这两个软件。 Git的下载地址&#xff1a; CNPM Binaries Mirrorhttps://registry.npmmirror.com/binary.html?pathgit-for-windows/ 寻找与自己电脑相配的软件版本就可以了。 Tor…

搭建跨境电商企业博客的指南

在跨境电商领域&#xff0c;企业博客不仅是展示品牌形象的窗口&#xff0c;也是连接全球客户的重要桥梁。一个精心搭建的企业博客能够提升品牌知名度、增强客户信任&#xff0c;并促进销售。 搭建企业博客的必要性 1. 建立品牌权威&#xff1a;通过高质量的内容&#xff0c;企…

渗透学习笔记(十一)Burp Suite 总结

声明&#xff01; 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以及泷羽sec团队无关&#…

课设CLion连接Ubuntu14makeQt项目出错解决汇总

在这之前需要注意以下几点&#xff1a; 1、需要 确保CLion能连接Ubuntu14 2、cmakelist.txt文件配置 3、知道部署路径&#xff1a; 问题一&#xff1a;/usr/bin/ld: cannot open output file GreedySnake: Is a directory 否则就会出现make以后应该生成一个可执行文件&…

【GO基础学习】gin的使用

文章目录 模版使用流程参数传递路由分组数据解析和绑定gin中间件 模版使用流程 package mainimport ("net/http""github.com/gin-gonic/gin" )func main() {// 1.创建路由r : gin.Default()// 2.绑定路由规则&#xff0c;执行的函数// gin.Context&#x…

磁编码器(Magnetic Encoder)

磁编码器&#xff08;Magnetic Encoder&#xff09;是一种传感器&#xff0c;它通过检测磁性材料的磁场变化来测量旋转或线性位置。编写用于读取磁编码器数据的C语言程序时&#xff0c;您需要根据具体的硬件接口和编码器类型进行调整。以下是一个基本的框架&#xff0c;假设我们…

Qt Creator项目构建配置说明

QT安装好之后&#xff0c;在安装目录的Tools\QtCreator\bin下找到qtcreator.exe文件并双击打开 点击文件-新建文件或项目 选择Qt Widgets Application 设置项目名称以及路径 make工具选择qmake&#xff08;cmake还未尝试过&#xff09; 设置主界面对应类的名称、父类&#…

智能边缘计算×软硬件一体化:开启全场景效能革命新征程(企业开发者作品)

边缘智能技术快速迭代&#xff0c;并与行业深度融合。它正重塑产业格局&#xff0c;催生新产品、新体验&#xff0c;带动终端需求增长。为促进边缘智能技术的进步与发展&#xff0c;拓展开发者的思路与能力&#xff0c;挖掘边缘智能应用的创新与潜能&#xff0c;高通技术公司联…

【React】- 跨域PDF预览、下载(改文件名)、打印

我们经常会碰到跨域来方位PDF&#xff0c;同时需要下载、打印的需求&#xff0c;通常由于浏览器的安全策略&#xff0c;可以预览&#xff0c;但是下载和打印可能会受限&#xff0c;这时候怎么办呢&#xff1f; 1.创建一个隐藏的标签 要下载 iframe 中的 PDF 文件&#xff0c;…

Ps:创建数据驱动的图像

在设计实践中&#xff0c;常常需要处理大量内容变化但设计格式统一的任务&#xff0c;例如批量生成名片、工作证、学生证、胸牌、奖状或证书甚至图册。这些工作如果逐一手动制作&#xff0c;不仅耗时费力&#xff0c;还容易出错。 为解决这一问题&#xff0c;Photoshop 提供了强…

Kotlin 协程基础知识总结六 —— 协程 Flow 的综合应用

1、项目描述与搭建 &#xff08;P92~P94&#xff09;我们会将几个 Flow 的应用实例放在同一个 Demo 中&#xff0c;主页就是一个 Activity 里包含一个按钮&#xff0c;点击按钮跳转到对应的功能展示页面上。整体架构采用一个 Activity 多个 Fragment 的结构&#xff0c;结合 J…

环,域,体,整区,理想,极大理想,

环&#xff1a; 定义&#xff1a; 加法交换群 乘法半群 分配律 域的定义&#xff1a; 加法交换群 乘法群&#xff08;去掉0元是交换群&#xff09; 分配律 Eg:比如整数集合不是域&#xff0c;因为对于乘法来说&#xff0c;去掉0后没有单位元了&#xff0c;但是是环 Eg…

关于Flutter应用国际化语言的设置

目录 1. Locale配置 2. 用户切换/启动自动加载缓存里面的locale 由于最近在开发app国际化设置的时候遇到一些问题&#xff0c;所以做出一些总结。 1. Locale配置 具体的初始化配置可以参考文档&#xff1a;i18n | Flutter 中文文档 - Flutter 中文开发者网站 - Flutter 值得…

【游戏开发】游戏生产的标准与工业化,管线Pipeline的概念与设计(项目管理,资产管理)

【游戏开发】游戏生产的标准与工业化&#xff0c;管线Pipeline的概念与设计&#xff08;项目管理&#xff0c;资产管理&#xff09; 文章目录 1、管线&#xff08;Pipeline&#xff09;是什么&#xff1f;1.1 管线解决什么问题&#xff08;例子&#xff09;1.2 一个动画电影的完…

探寻 OneCode 核心优势:MVVM 进阶与前后端协同之魅

在当今的软件开发领域&#xff0c;高效、可维护且功能强大的架构是开发者们不懈追求的目标。OneCode 凭借其独特的增强版 MVVM 架构、前后端一体化特性&#xff0c;以及创新的技术如 OneCode DSM&#xff08;Domain-Specific Modeling&#xff0c;领域特定建模&#xff09;、视…

机器人C++开源库The Robotics Library (RL)使用手册(三)

进入VS工程,我们先看看这些功能函数及其依赖库的分布关系: rl命名空间下,主要有八大模块。 搞定VS后将逐个拆解。 1、编译运行 根据报错提示,配置相应错误的库(根据每个人安装位置不同而不同,我的路径如下:) 编译所有,Release版本耗时大约10分钟。 以rlPlan运动…

ISP代理与住宅代理的区别

了解ISP代理 通常称为互联网服务提供商代理&#xff0c;通过服务提供商将用户直接连接到互联网。这些代理利用互联网服务提供商的网络&#xff0c;通常提供广泛的IP地址池。ISP代理通常快速可靠&#xff0c;非常适合一般浏览和常规互联网使用场景。 了解住宅代理 相比之下&a…