当前位置: 首页 > 编程日记 > 正文

BZOJ.5249.[九省联考2018]iiidx(贪心 线段树)

BZOJ
LOJ
洛谷


\(d_i\)不同就不用说了,建出树来\(DFS\)一遍。
对于\(d_i\)不同的情况:

Solution 1:
xxy tql!

考虑如何把这些数依次填到树里。
首先对于已解锁的节点\(x\)(已解锁是指父节点已经处理完的点,刚开始就是\(fa[x]=0\)\(x\)),为其子树预定\(sz[x]\)大小的位置。
\(d_i\)从小到大排序依次枚举,每次要尽量往\(1,2,...,n\)这个序列中尽量靠后的位置填(填到\(p\)表示\(Ans_p=d_i\))。
假设现在最小的数是\(v\),且一共有\(k\)个相同的\(v\),首先我们要找到最靠右的位置\(p\)\(p\)满足\(p\sim n\)需求数至少为\(k\),然后在\(p\)处填上\(v\)(此时一定会在\(p\)\(v\),因为比\(p\)大的空位置全加起来也不够\(k\)个);然后把\(p\)位置的\(sz[p]\)删掉,"解锁"\(p\)的儿子,即再在\(son_p\)处预定\(sz[son_p]\)的大小,看能不能之后填数时填更优的某个\(son_p\)处。
然后\(k\)-=\(1\),重复上面的过程(找一个满足...的最靠右的位置\(p\)...),直到\(k=0\)
这些都可以用线段树实现。复杂度\(O(n\log n)\)。常数比下面那种写法小。

这种方法可以用树状数组代替,跑得飞快(树状数组二分...orz不会写懒得看):https://loj.ac/submission/89252。


Solution 2:
从小到大枚举每个位置\(x\),我们要填一个尽量大的数\(v\),满足大于等于\(v\)且没有被用过的数至少有\(sz[x]\)个。
假设对于位置\(x\),我们找到了这个\(v\),但是大于等于\(v\)的数可能不只有\(sz[x]\)个,且我们不知道要选出哪\(sz[x]\)个。

把所有数从大到小排序,每个位置\(i\)维护它和它左边还可以选多少数\(A_i\)(初始\(A_i=i\))。
当给位置\(x\)找到合适的数\(v\)时,\(v\)左边的数用哪些不确定,但\(v\)\(v\)右边的数的左边被用到了\(sz[x]\)个是确定的,所以给\(A_v\sim A_{d_n}\)都减掉\(sz[x]\)
这样对于数\(v\),它左边还可以用的数的个数就是\(\min\{A_v,A_{v+1},...,A_{d_n}\}\).
这样就可以在线段树上二分找适合\(x\)\(v\)了。具体就是如果右区间的最小值\(<sz[x]\),说明右区间不满足,那左区间肯定也不满足,递归到右区间;否则如果\(\geq sz[x]\),右区间可行,但还需要递归到左区间看看是否可行,如果不行就直接返回相邻右区间的第一个位置。

枚举到一个点\(x\)时,如果它有父亲,那要把它父亲\(fa[x]\)为这些子树预定的值删掉(因为之前就是为了给这些子树留空间啊,枚举到这些子树的时候当然要把之前占的位置空出来了),然后找个合适的位置给\(x\)子树预定\(sz[x]\)的大小。(注意每个值别删了多次)
如果有一些相同的数\(v\)可以选,显然现在把最右边的那个\(v\)放到当前位置更优。也就是对于相同的数要从右往左依次分。

复杂度\(O(n\log n)\)


这道题还帮我拿到了LOJ 332333的评测记录2333.

Solution 1:

//18888KB   3000MS(233好整)->18892kb  2536ms
#include <cstdio>
#include <cctype>
#include <algorithm>
#define eps 1e-9
//#define gc() getchar()
#define MAXIN 500000
#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
typedef long long LL;
const int N=5e5+5;int H[N],nxt[N],sz[N];
char IN[MAXIN],*SS=IN,*TT=IN;
struct Segment_Tree
{#define ls rt<<1#define rs rt<<1|1#define lson l,m,ls#define rson m+1,r,rs#define S N<<2int sum[S];#undef Svoid Modify(int l,int r,int rt,int p,int v){sum[rt]+=v;if(l==r) return;int m=l+r>>1;p<=m ? Modify(lson,p,v) : Modify(rson,p,v);}int Query(int l,int r,int rt,int k){if(l==r) return l;int m=l+r>>1;return sum[rs]>=k ? Query(rson,k) : Query(lson,k-sum[rs]);}
}T;inline int read()
{int now=0;register char c=gc();for(;!isdigit(c);c=gc());for(;isdigit(c);now=now*10+c-48,c=gc());return now;
}
inline double readdb()
{double x=0,y=0.1;register char c=gc();for(;!isdigit(c);c=gc());for(;isdigit(c);x=x*10+c-48,c=gc());for(c=='.'&&(c=gc());isdigit(c);x+=y*(c-48),y*=0.1,c=gc());return x;
}
inline void AE(int u,int v)
{nxt[v]=H[u], H[u]=v, sz[u]+=sz[v];
}int main()
{static int A[N],Ans[N];const int n=read(); const double K=readdb();for(int i=1; i<=n; ++i) A[i]=read(), sz[i]=1;std::sort(A+1,A+1+n);for(int i=n; i; --i) AE(int(i/K+eps),i);// or floor(i/K) 这样不需要eps...神奇...for(int v=H[0]; v; v=nxt[v]) T.Modify(1,n,1,v,sz[v]);for(int i=1,j=1; i<=n; i=j){while(A[i]==A[j]) ++j;for(int k=j-i; k; --k){int x=T.Query(1,n,1,k);Ans[x]=A[i], T.Modify(1,n,1,x,-sz[x]);for(int v=H[x]; v; v=nxt[v]) T.Modify(1,n,1,v,sz[v]);}}for(int i=1; i<=n; ++i) printf("%d ",Ans[i]);return 0;
}

Solution 2:

//28656kb   4280ms
#include <cstdio>
#include <cctype>
#include <algorithm>
#include <functional>
#define eps 1e-9
//#define gc() getchar()
#define MAXIN 500000
#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
typedef long long LL;
const int N=5e5+5;char IN[MAXIN],*SS=IN,*TT=IN;
struct Segment_Tree
{#define ls rt<<1#define rs rt<<1|1#define lson l,m,ls#define rson m+1,r,rs#define S N<<2int mn[S],tag[S];#undef S#define Upd(rt,v) mn[rt]+=v, tag[rt]+=v#define Update(rt) mn[rt]=std::min(mn[ls],mn[rs])inline void PushDown(int rt){Upd(ls,tag[rt]), Upd(rs,tag[rt]), tag[rt]=0;}void Build(int l,int r,int rt){mn[rt]=l;if(l!=r){int m=l+r>>1;Build(lson), Build(rson);}}void Modify(int l,int r,int rt,int p,int v){if(p<=l) {Upd(rt,v); return;}if(tag[rt]) PushDown(rt);int m=l+r>>1;Modify(rson,p,v);if(p<=m) Modify(lson,p,v);Update(rt);}int Query(int l,int r,int rt,int k){while(l!=r){if(tag[rt]) PushDown(rt);int m=l+r>>1;mn[rs]>=k ? (r=m,rt=ls) : (l=m+1,rt=rs);}return mn[rt]>=k?l:l+1;}
}T;inline int read()
{int now=0;register char c=gc();for(;!isdigit(c);c=gc());for(;isdigit(c);now=now*10+c-48,c=gc());return now;
}
inline double readdb()
{double x=0,y=0.1;register char c=gc();for(;!isdigit(c);c=gc());for(;isdigit(c);x=x*10+c-48,c=gc());for(c=='.'&&(c=gc());isdigit(c);x+=y*(c-48),y*=0.1,c=gc());return x;
}int main()
{static int A[N],Ans[N],sz[N],fa[N],R[N],cnt[N];const int n=read(); const double K=readdb();for(int i=1; i<=n; ++i) A[i]=read(), sz[i]=1;std::sort(A+1,A+1+n,std::greater<int>());T.Build(1,n,1);for(int i=n; i; --i) sz[fa[i]=(int)(i/K+eps)]+=sz[i], R[i]=A[i]==A[i+1]?R[i+1]:i;for(int i=1; i<=n; ++i){if(fa[i] && fa[i]!=fa[i-1]) T.Modify(1,n,1,Ans[fa[i]],sz[fa[i]]-1);int p=T.Query(1,n,1,sz[i]);p=R[p], ++cnt[p], p-=(cnt[p]-1), Ans[i]=p;T.Modify(1,n,1,p,-sz[i]);}for(int i=1; i<=n; ++i) printf("%d ",A[Ans[i]]);return 0;
}

转载于:https://www.cnblogs.com/SovietPower/p/10360118.html

相关文章:

leetcode-376 摆动序列

如果连续数字之间的差严格地在正数和负数之间交替&#xff0c;则数字序列称为摆动序列。第一个差&#xff08;如果存在的话&#xff09;可能是正数或负数。少于两个元素的序列也是摆动序列。 例如&#xff0c; [1,7,4,9,2,5] 是一个摆动序列&#xff0c;因为差值 (6,-3,5,-7,3…

bootstrap3中关于布局的两种样式

container&#xff1a;用.container包裹的内容即可实现居中对齐。注意&#xff0c;由于在各分辨率下面都设置了padding 和 固定宽度&#xff0c;.container不能嵌套。row&#xff1a;栏栅系统是把父容器平均分为12列。注意&#xff0c;row可以被嵌套。 通过下表可以详细查看Boo…

adg oracle 架构_云化双活的架构演进,宁夏银行新核心搭载Oracle 19c投产上线

云和恩墨顺利完成宁夏银行新数据中心数据库平台的建设&#xff0c;包括新数据中心RAC搭建、DG搭建、旧数据中心到新数据中心的数据迁移&#xff0c;以及在整个项目生命周期中的实施规范、性能测试保障、压力测试等。6月12日&#xff0c;宁夏银行数据库完成全部迁移&#xff0c;…

MFC里ON_COMMAND_RANGE消息映射的ID问题

今天在工作中遇到一个问题&#xff0c;一个动态菜单&#xff0c;每个菜单的菜单项ID是我自己定义的&#xff0c;定义如下&#xff1a; #define IDM_SEARCHRECORD0 222240 #define IDM_SEARCHRECORD1 222241 #define IDM_SEARCHRECORD2 222242 #define IDM_SEARCHRECORD3 …

反射拷贝对象的思路:

0 根据构造器创建对象 1.获取传入进来的对象的字段 2.获取字段的类型 3.拼接 set 与get方法 4 获取传入进来的对象的值 并设置给新对象转载于:https://www.cnblogs.com/classmethond/p/10362263.html

leetcode-402 移掉K位数组

给定一个以字符串表示的非负整数 num&#xff0c;移除这个数中的 k 位数字&#xff0c;使得剩下的数字最小。 注意: num 的长度小于 10002 且 ≥ k。 num 不会包含任何前导零。 示例 1 : 输入: num “1432219”, k 3 输出: “1219” 解释: 移除掉三个数字 4, 3, 和 2形成一…

c++ using 前置声明_C++ 类的前置声明

今天在研究C”接口与实现分离“的时候遇到了一个问题&#xff0c;看似很小&#xff0c;然后背后的东西确值得让人深思&#xff01;感觉在学习的过程中有太多的为什么&#xff0c;而每一个为什么背后都隐藏着一些原理和目的&#xff0c;所以得多问自己”为什么“&#xff0c;这样…

测试用的序列化方法

对于实体&#xff0c;进行底层方法测试的时候&#xff0c;经常逐一赋值很麻烦&#xff0c;网上找到序列化xml方法&#xff0c;感觉挺好用的。 前端调用方法时&#xff0c;将实体序列化写入xml文件 //xml路径string filePath "D:\1.xml";using (System.IO.StreamWrit…

HighChart学习-更新数据data Series与重绘

一&#xff1a;HighChart介绍 基于JQuery的纯JavaScript的图标库&#xff0c;支持各种图表显示&#xff0c;同时还支持Mootools 与Prototype详细版本支持在这里&#xff1a; JQuery 1.3.2 - 1.9.x. 2.0.x for modern browsers Mootools 1.2.5 - 1.4.5 Prototype 1.7 支持目…

shell代码模板

批量ssh登录机器#site_search_hosts 10.4.16.205,10.4.20.87,10.4.20.88,10.4.20.89,10.4.20.90,10.4.20.92,10.4.20.93,10.4.21.51,10.4.21.52,10.4.21.53,10.4.21.54,10.4.33.136,10.4.33.137,10.4.33.138,10.4.33.139,10.4.33.140site_search_hosts10.4.16.205,10.4.20.87,1…

leetcode-55 跳跃游戏

给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个位置。 示例 1: 输入: [2,3,1,1,4] 输出: true 解释: 我们可以先跳 1 步&#xff0c;从位置 0 到达 位置 1, 然后再从位置 1…

子分类账知识学习(汇总网上比较有用的资料)

子模块和GL之间关联的变化 12i在功能模块上的变化很多&#xff0c;比如&#xff0c;基本每个模块都启用了MOAC特性&#xff0c;新增加了子帐模块&#xff0c;税模块等等很多新的模块&#xff0c;OPM库存和离散库存集成了。不过这些变化中&#xff0c;大部分不是我们需要重点…

zynqpl端时钟_第十一章 ZYNQ-MIZ701 PS读写PL端BRAM

本篇文章目的是使用Block Memory进行PS和PL的数据交互或者数据共享&#xff0c;通过zynq PS端的Master GP0端口向BRAM写数据&#xff0c;然后再通过PS端的Mater GP1把数据读出来&#xff0c;将结果打印输出到串口终端显示。涉及到AXI BRAM Controller 和 Block Memery Generato…

nagios报警的问题

最近我写了关于naigos监控的安装与配置的技术文档&#xff0c;公司运维按照我的文档部署naigos&#xff0c;发现不能发送报警邮件&#xff0c;经过我的检查&#xff0c;发现问题如下&#xff1a;1、hosts里的配置[rootnagios ~]# cat /etc/hosts # Do not remove the followin…

机器学习常见的分类算法的优缺点

1. 前言 在机器学习中&#xff0c;种类最多的一类算法要属很类算法&#xff0c;本文对机器学习中的各种分类算法的优缺点做一个总结。 2. 贝叶斯分类法 2.1 优点 所需估计的参数少&#xff0c;对于缺失数据不敏感。有着坚实的数学基础&#xff0c;以及稳定的分类效率。2.2 缺点…

公司新来一个同事:为什么 HashMap 不能一边遍历一边删除?一下子把我问懵了!

前段时间,同事在代码中KW扫描的时候出现这样一条:上面出现这样的原因是在使用foreach对HashMap进行遍历时,同时进行put赋值操作会有问题,异常ConcurrentModificationException。于是帮同简单的看了一下,印象中集合类在进行遍历时同时进行删除或者添加操作时需要谨慎,一般使用迭代器进行操作。于是告诉同事,应该使用迭代器Iterator来对集合元素进行操作。同事问我为什么?这一下子把我问蒙了?对啊,只是记得这样用不可以,但是好像自己从来没有细究过为什么?

一文搞懂MySQL索引

官方介绍索引是帮助MySQL高效获取数据的数据结构。更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度。一般来说索引本身也很大,不可能全部存储在内存中,因此索引往往是存储在磁盘上的文件中的(可能存储在单独的索引文件中,也可能和数据一起存储在数据文件中)。我们通常所说的索引,包括聚集索引、覆盖索引、组合索引、前缀索引、唯一索引等,没有特别说明,默认都是使用B+树结构组织(多路搜索树,并不一定是二叉的)的索引。看到这里,你是不是对于自己的sql语句里面的索引的有了更多优化想法呢。

leetcode-45 跳跃游戏II

给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 你的目标是使用最少的跳跃次数到达数组的最后一个位置。 示例: 输入: [2,3,1,1,4] 输出: 2 解释: 跳到最后一个位置的最小跳跃数是 2。 从下标为 0 跳到下标…

做技术到底可以做到哪种地步-技术为什么越走越窄 (转)

尽管做技术已经有不少年头了&#xff0c;不管是犹犹豫豫还是坚定不移&#xff0c;我们走到了现在&#xff0c;依然走在技术这条路上。 不管我们处于何种职位&#xff0c;拿着哪种薪水&#xff0c;其实&#xff0c;我们会是不是的问问自己“做技术到底可以做到那种地步”&#x…

linux本地agent执行脚本_github 4.4K星|马哥教育企业教练团队研发一款轻量级、无Agent自动化运维平台...

马哥教育企业教练团队研发了一款自动化运维平台系统—Spug&#xff0c;上线后广受中小运维爱好者喜爱&#xff0c;目前github4.4k星&#xff0c;已经成为自动化热门项目。2020年了&#xff0c;运维不会搞运维自动化&#xff0c;都不好意思说自己做运维的了&#xff0c;大一点的…

mysql 数据目录更改

[CentOS]MySQL更改数据文件存储目录环境&#xff1a;CentOS(Linux) Mysql5.X 1.如果MySQL已经启动的话&#xff0c;需要先停止MySQL的运行#service mysqld stop2.home 目录下新建目录[data]/home #mkdir data3.移动MySQL默认数据库文件#mv /var/lib/mysql /home/data4.修改MySQ…

leetcode-452 用最少数量的箭引爆气球

在二维空间中有许多球形的气球。对于每个气球&#xff0c;提供的输入是水平方向上&#xff0c;气球直径的开始和结束坐标。由于它是水平的&#xff0c;所以y坐标并不重要&#xff0c;因此只要知道开始和结束的x坐标就足够了。开始坐标总是小于结束坐标。平面内最多存在104个气球…

ssm 异常捕获 统一处理_SpringMVC 统一异常处理介绍及实战

背景什么是统一异常处理目标统一异常处理实战用 Assert(断言) 替换 throw exception定义统一异常处理器类扩展总结《Java 2019 超神之路》《Dubbo 实现原理与源码解析 —— 精品合集》《Spring 实现原理与源码解析 —— 精品合集》《MyBatis 实现原理与源码解析 —— 精品合集》…

【iOS开发】企业版证书($299)In-House方式发布指南 (转)

一、明确几个概念 1、企业版IDP&#xff1a;即iOS Development Enterprise Program。注意是$299&#xff0f;Year那种&#xff0c;并不是$99/Year的那种。 2、In House&#xff1a;是只企业内部发布&#xff0c;仅限企业内部人员使用。 二、In-House方式特点 1、不能发布到Appl…

苹果所有常用证书,appID,Provisioning Profiles配置说明及制作图文教程(精)

概述&#xff1a; 苹果的证书繁锁复杂&#xff0c;制作管理相当麻烦&#xff0c;今天决定重置一个游戏项目中的所有证书&#xff0c;做了这么多次还是感觉很纠结&#xff0c;索性直接记录下来&#xff0c;日后你我他查阅都方便&#xff1b; 首先得描述一下各个证书的定位&#…

ES6语法~解构赋值、箭头函数、class类继承及属性方法、map、set、symbol、rest、new.target、 Object.entries......

2015年6月17日 ECMAScript 6发布正式版本 前面介绍基本语法, 后面为class用法及属性方法、set、symbol、rest等语法. 一、基本语法: 1、 定义变量&#xff1a;let 使用var 定义的变量没有{ }限制&#xff0c;在条件中定义的i&#xff0c;全局中都可以使用&#xff0c…

读书:历史 -- 东印度公司

浅田实 — 日本 文学博士、英国近世史学专家 东印度公司曾经为英国殖民印度&#xff0c;扮演过冲锋陷阵的历史角色。 富可敌国来形容东印度公司绰绰有余&#xff0c;它的崛起和衰落是时代变迁的缩影。 英国发起的第一次工业革命迫切需要资本的输入和输出来带动蒸汽齿轮得高速转…

2014腾讯校园招聘研发笔试题

嘿嘿转载于:https://www.cnblogs.com/churi/p/3969749.html

用74l138实现一个一位全减器_用pygame实现一个简单的五子棋游戏

准备python基础相关准备&#xff1a;pygame的基础知识&#xff0c;参考目光博客的“用Python和Pygame写游戏-从入门到精通”安装python 3.8.0 在python官网下载&#xff0c;不多说。安装pygame&#xff0c;命令&#xff1a;pip install pygame如安装较慢&#xff0c;可以参考如…

大量LAST_ACK 的分析过程

2019独角兽企业重金招聘Python工程师标准>>> 记录一下自己的思想过程 现象:在netstat的时候发现大量处于LAST_ACK状态的TCP连接&#xff0c;达到在ESTABLISHED状态的90%以上 [rootccsafe ~]# netstat -ant|fgrep ":"|cut -b 77-90|sort |uniq -c …