CF297C Splitting the Uniqueness 题解

CF297C Splitting the Uniqueness 题解

非常好构造题,使我的草稿纸旋转。

解法

我们记输入的数组为 a a a,需要输出的两个数组为 b , c b,c b,c(因为当时起变量名起的)。

考虑利用 a i a_i ai 互不相同的性质。

先将 a i a_i ai 升序排序。因为题中保证 a i a_i ai 互不相同,所以相邻两数的差至少为 1 1 1,从而 a i ≥ i − 1 a_i \ge i - 1 aii1

考虑到最多有 ⌈ n 3 ⌉ \lceil \dfrac{n}{3} \rceil 3n 个重复数字,即为需要至少有 ⌊ 2 n 3 ⌋ \lfloor \dfrac{2n}{3} \rfloor 32n 种不同数字。我们可以将整个数组等分为 3 3 3 段,分别是 [ 1 , ⌊ n 3 ⌋ ] [1,\lfloor \dfrac{n}{3} \rfloor ] [1,3n⌋] ( ⌊ n 3 ⌋ , ⌊ 2 n 3 ⌋ ] (\lfloor \dfrac{n}{3} \rfloor,\lfloor \dfrac{2n}{3} \rfloor] (⌊3n,32n⌋] ( ⌊ 2 n 3 ⌋ , n ] (\lfloor \dfrac{2n}{3} \rfloor,n] (⌊32n,n]。具体构造如下图。

图片

为什么这么构造是对的?

显然对于 c c c 数组,第二段和第三段的数互不相同,满足至少有 ⌊ 2 n 3 ⌋ \lfloor \dfrac{2n}{3} \rfloor 32n 种不同数字。考虑为什么 b b b 数组至少有 ⌊ 2 n 3 ⌋ \lfloor \dfrac{2n}{3} \rfloor 32n 种不同数字。

观察第一段和第三段,因为 a i ≥ i − 1 a_i \ge i-1 aii1,所以第三段的第一个 a i a_i ai 满足 a i ≥ 2 n 3 a_i \ge \dfrac{2n}{3} ai32n,而 n − ⌊ 2 n 3 ⌋ − 1 = ⌈ n 3 ⌉ − 1 n - \lfloor \dfrac{2n}{3} \rfloor -1 = \lceil \dfrac{n}{3} \rceil - 1 n32n1=3n1,所以 c i c_i ci 满足 c i ≥ n 3 c_i \ge \dfrac{n}{3} ci3n,而在第三段 a a a 单调上升, c c c 单调下降,所以 b b b 单调上升,所以 b b b 数组在第一段和第三段互不相同。

代码

#include<bits/stdc++.h>
namespace fast_IO
{/*** 没啥用的快读快写*/
};
using namespace fast_IO;
int n,b[100010],c[100010],fir,sec;
struct node
{int val,ord;inline bool operator<(const node rhs) const{return val<rhs.val;}
};
node a[100010];
int main()
{in>>n,fir=n/3,sec=n*2/3;for(int i=1;i<=n;i++) in>>a[i].val,a[i].ord=i;std::sort(a+1,a+n+1);for(int i=1;i<=fir;i++) b[a[i].ord]=i-1,c[a[i].ord]=a[i].val-b[a[i].ord];for(int i=fir+1;i<=sec;i++) c[a[i].ord]=i-1,b[a[i].ord]=a[i].val-c[a[i].ord];for(int i=n;i>sec;i--) c[a[i].ord]=n-i,b[a[i].ord]=a[i].val-c[a[i].ord];out<<"YES\n";for(int i=1;i<=n;i++) out<<b[i]<<' ';out<<'\n';for(int i=1;i<=n;i++) out<<c[i]<<' ';fwrite(Ouf,1,p3-Ouf,stdout),fflush(stdout);return 0;
}

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

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

相关文章

二叉树顺序结构——堆的结构与实现

二叉树顺序结构——堆的结构与实现 一、二叉树的顺序结构二、堆的概念及结构三、堆的实现堆向下调整算法堆的创建建堆时间复杂度堆的插入(堆向上调整算法)堆的删除堆的代码实现(使用VS2022的C语言)初始化、销毁构建、插入、删除返回堆顶元素、判空、返回有效元素个数 四、完整 …

20240610 基于QGIS生成地区示意图的地图shp文件

目录 本文目标前置条件具体步骤1. 创建Project2. 插入世界地图3. 对地区示意图进行地理匹配4. 创建shp文件&#xff0c;勾画轨迹 注意事项 本文目标 基于QGIS生成地区示意图的地图shp文件&#xff0c;此shp文件可以用来学习&#xff0c;但是未经审批不可用于发表。 前置条件 …

Python基础教程(十一):数据结构汇总梳理

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; &#x1f49d;&#x1f49…

10.3 Go 同步与通信

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

Android Studio Jellyfish版本修改project使用特定jdk版本的步骤

android studio总是把这些东西改来改去让人十分恼火&#xff0c;IDE本身改来改去就让人无法上手就立即工作&#xff0c;很多时间浪费在IDE和gradle的配置和奇奇怪怪现象的斗智斗勇上&#xff0c;搞Android是真的有点浪费生命。一入此坑深不见底 jellyfish版安卓studio已经无法通…

算法 | 剪枝函数以及几种形式回溯法和分支限界法的区别算法特性分支限界法的思想分支限界法的基本步骤Prim和Kruscal回溯法的效率

what is 剪枝函数&#xff1f; 是对该问题能否得到最优解或者可行解的约束 限界函数&#xff1a;最优解 约束函数&#xff1a;可行解 回溯法和分支限界法的区别&#xff1a; 异&#xff1a; 回溯法分支限界法一次生成/扩展一个结点一次生成所有的孩子结点BFSDFS/最小耗费优…

Docker高级篇之轻量化可视化工具Portainer

文章目录 1. 简介2. Portainer安装 1. 简介 Portianer是一款轻量级的应用&#xff0c;它提供了图形化界面&#xff0c;用于方便管理Docker环境&#xff0c;包括单机环境和集成环境。 2. Portainer安装 官网&#xff1a;https://www.portainer.io 这里我们使用docker命令安装&…

深入探讨API接口:定义、作用、设计原则及常见问题

API&#xff08;Application Programming Interface&#xff09;即应用程序编程接口&#xff0c;是软件系统间相互通信的桥梁&#xff0c;提供了一系列的约定和工具&#xff0c;使不同软件系统之间能够实现数据交换和功能调用。在软件开发中&#xff0c;API接口扮演着至关重要的…

渗透测试之内核安全系列课程:Rootkit技术初探(一)

今天&#xff0c;我们来讲一下内核安全&#xff01; 本文章仅提供学习&#xff0c;切勿将其用于不法手段&#xff01; 目前&#xff0c;在渗透测试领域&#xff0c;主要分为了两个发展方向&#xff0c;分别为Web攻防领域和PWN&#xff08;二进制安全&#xff09;攻防领域。在…

状态管理Vuex

官网&#xff1a;Vuex 是什么&#xff1f; | Vuex (vuejs.org)https://v3.vuex.vuejs.org/zh/ 创建一个vue2的新项目名为vuex-demo&#xff0c;安装命令 npm install vuex3 新建index.js import Vue from vue import Vuex from vuexVue.use(Vuex)const store new Vuex.Store(…

私域怎么引流?

在数字化营销日益重要的今天&#xff0c;私域流量成为了企业竞争的新焦点。私域流量指的是企业在自己的平台上所拥有和控制的用户资源&#xff0c;如企业官网、社交媒体账号、APP等。如何有效地进行私域引流&#xff0c;即将潜在用户引导至企业的私域平台&#xff0c;成为企业营…

java编码转换怎样实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串

在Java中&#xff0c;直接进行GB2312到ISO-8859-1的编码转换可能会导致数据丢失&#xff0c;因为ISO-8859-1&#xff08;也称为Latin-1&#xff09;是一个单字节编码&#xff0c;它不支持像GB2312这样的多字节编码中的所有字符。GB2312主要用于简体中文&#xff0c;而ISO-8859-…

记录自己在xss-labs的通关记录

第十一关&#xff08;referer&#xff09; 直接查看网页源代码&#xff0c;发现四个input被隐藏&#xff0c;不难看出&#xff0c;第四个名为t_ref的<input>标签是http头referer的参数&#xff08;就是由啥地址转跳到这里的&#xff0c;http头的referer会记录有&#xf…

ES6中如何使用class和extends关键字实现继承?

在ES6中&#xff0c;可以使用class关键字来定义类&#xff0c;使用extends关键字来实现继承。下面是一个示例&#xff1a; // 父类 class Parent {constructor(name) {this.name name;}sayHello() {console.log(Hello, my name is ${this.name});} }// 子类 class Child ex…

操作系统安全:Windows系统安全配置,Windows安全基线检查加固

「作者简介」&#xff1a;2022年北京冬奥会网络安全中国代表队&#xff0c;CSDN Top100&#xff0c;就职奇安信多年&#xff0c;以实战工作为基础对安全知识体系进行总结与归纳&#xff0c;著作适用于快速入门的 《网络安全自学教程》&#xff0c;内容涵盖系统安全、信息收集等…

如何用R语言ggplot2画折线图

文章目录 前言一、数据集二、ggplot2画图1、全部代码2、细节拆分1&#xff09;导包2&#xff09;创建图形对象3&#xff09;主题设置4&#xff09;轴设置5&#xff09;图例设置6&#xff09;颜色7&#xff09;保存图片 前言 一、数据集 数据下载链接见文章顶部 数据&#xff1a…

STM32 Customer BootLoader 刷新项目 (一) STM32CubeMX UART串口通信工程搭建

STM32 Customer BootLoader 刷新项目 (一) STM32CubeMX UART串口通信工程搭建 文章目录 STM32 Customer BootLoader 刷新项目 (一) STM32CubeMX UART串口通信工程搭建功能与作用典型工作流程 1. 硬件原理图介绍2. STM32 CubeMX工程搭建2.1 创建工程2.2 系统配置2.3 USART串口配…

tokenization(一)概述

文章目录 背景基于词&#xff08;Word-based&#xff09;基于字符&#xff08;Character-based&#xff09;子词词元化&#xff08;Subword tokenization&#xff09; 背景 tokenization是包括大语言模型在内所有自然语言处理的任务的基础步骤&#xff0c;其目标是将文本数据转…

【面试干货】聚集索引和非聚集索引区别?

【面试干货】聚集索引和非聚集索引区别? 1、聚集索引&#xff08;Clustered Index&#xff09;1.1 特点1.2 例子 2、非聚集索引&#xff08;Nonclustered Index&#xff09;2.1 特点2.2 例子 3、根本区别 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&…

Sklearn的安装和用法

安装sklearn相对简单&#xff0c;因为它是一个Python库&#xff0c;可以通过Python的包管理器pip来安装。 Windows、macOS和Linux通用步骤&#xff1a; 确保Python已安装&#xff1a; sklearn是基于Python的&#xff0c;所以首先确保你的计算机上安装了Python。推荐使用Pytho…