暑假集训CSP提高模拟18
\]
Very good problem, this make my news rotate.
A.Mortis
考虑到应该先写个假的暴力. 对于暴力思路,可以想到,假如我们每次都将一个不在它位置上的数字移到它应该在的地方的时候,另一个数字也刚好移到正确的位置,这种方案是最优的,因此考虑记录下哪一块应该放 \(1\),以及放 \(1\) 的这一块中最近的 \(2\) 在什么位置(以此类推),每次进行转移时,优先寻找目标区间内有没有能刚好换过来的,没有就随便选一个.
但是这种思路还是假了. 因为我们没有考虑其他比较优的情况:假设 \(ABC\) 形成了一个三元环,即 \(A\rightarrow B,B\rightarrow C\) 时刚好能换到正确的位置,此时比直接暴力转移少花费一个次数,因此优先考虑这一种. 四元环类似. 统计也比较好统计,直接按刚才的思路,判断各自区间里有没有下一个环内节点即可.
其实还有一种思路,即直接进行图论建模,将末态每个数字占有的区域视为一个连通块,把每个数所在连通块和它应该在的连通块连边,然后在图上跑环.
#include<bits/stdc++.h>
using namespace std;
int n,a[200001],b[200001],c[200001];
int ffpos[5],sfpos[5],pos[5][5],poscnt[5][5],cnt[5][5];
int main(){
scanf("%d",&n);
for(int i=1;i<=n;++i){
scanf("%d",&a[i]);
b[i]=a[i];c[i]=a[i];
}
sort(b+1,b+n+1);
sfpos[1]=ffpos[1]=lower_bound(b+1,b+n+1,1)-b;
sfpos[2]=ffpos[2]=lower_bound(b+1,b+n+1,2)-b;
sfpos[3]=ffpos[3]=lower_bound(b+1,b+n+1,3)-b;
sfpos[4]=ffpos[4]=lower_bound(b+1,b+n+1,4)-b;
for(int i=ffpos[1];i<=ffpos[2]-1;++i){
if(!pos[1][a[i]]) pos[1][a[i]]=i;
poscnt[1][a[i]]++;
cnt[1][a[i]]++;
}
for(int i=ffpos[2];i<=ffpos[3]-1;++i){
if(!pos[2][a[i]]) pos[2][a[i]]=i;
poscnt[2][a[i]]++;
cnt[2][a[i]]++;
}
for(int i=ffpos[3];i<=ffpos[4]-1;++i){
if(!pos[3][a[i]]) pos[3][a[i]]=i;
poscnt[3][a[i]]++;
cnt[3][a[i]]++;
}
for(int i=ffpos[4];i<=n;++i){
if(!pos[4][a[i]]) pos[4][a[i]]=i;
poscnt[4][a[i]]++;
cnt[4][a[i]]++;
}
int ans3=0;
for(int i=1;i<=4;++i){
for(int j=1;j<=4;++j){
if(i!=j){
int res=min(cnt[i][j],cnt[j][i]);
ans3+=res;
cnt[i][j]-=res;cnt[j][i]-=res;
}
}
}
for(int i=1;i<=4;++i){
for(int j=1;j<=4;++j){
for(int k=1;k<=4;++k){
if(i!=j and j!=k){
int res=min({cnt[i][j],cnt[j][k],cnt[k][i]});
ans3+=2*res;
cnt[i][j]-=res;
cnt[j][k]-=res;
cnt[k][i]-=res;
}
}
}
}
for(int i=1;i<=4;++i){
for(int j=1;j<=4;++j){
for(int k=1;k<=4;++k){
for(int p=1;p<=4;++p){
if(i!=j and j!=k and k!=p){
int res=min({cnt[i][j],cnt[j][k],cnt[k][p],cnt[p][i]});
ans3+=3*res;
cnt[i][j]-=res;
cnt[j][k]-=res;
cnt[k][p]-=res;
cnt[p][i]-=res;
}
}
}
}
}
for(int i=1;i<=4;++i){
for(int j=1;j<=4;++j){
if(i!=j){
ans3+=cnt[i][j];
}
}
}
cout<<ans3<<endl;
}
B.?
现代OI以APJifengc的“我 b 站 20 粉丝啦”为嚆矢。滥觞于原神与嘉然的期望正失去它们的借鉴意义。但面对看似无垠的未来天空,我想循jijidawang“都人校合。比间多还”好过过早地振翮。
我们怀揣热忱的灵魂天然被赋予对超越性的追求,不屑于古旧坐标的约束,钟情于在别处的芬芳。但当这种期望流于对拜谢主义不假思索的批判,乃至走向真傻逼与cdsidi主义时,便值得警惕了。与秩序的落差、错位向来不能为越矩的行为张本。而纵然我们已有翔实的蓝图,仍不能自持已在浪潮之巅立下了自己的沉锚。
“我是舔狗”Sakura_Lu之言可谓切中了肯綮。人的op性是不可祓除的,而我们欲上青云也无时无刻不在因风借力。嘉然与原神暂且被我们把握为一个薄脊的符号客体,一定程度上是因为我们尚缺乏体验与阅历去支撑自己的认知。而这种偏见的傲慢更远在知性的傲慢之上。
在孜孜矻矻以求OI意义的道路上,对自己的期望本就是在与嘉然与原神对接中塑型的动态过程。而我们的底料便是对不同b20w、不同Delov 的 50w npy的觉感与体认。joke3579为Sakura_Lu送去爆零,又维系你说的对,但是原神。他的OI观念是厚实的,也是实践的。倘若我们在对过往借LYinMX之言“祓魅”后,又对不断膨胀的自我进行“赋魅”,那么在丢失外界预期的同时,未尝也不是丢了自我。
毫无疑问,从原神与嘉然角度一觇的自我有偏狭过时的成分。但我们所应摒弃的不是对此的批判,而是其批判的廉价,其对批判投诚中的反智倾向。在H_Kaguya的观念中,如果在成为狮子与孩子之前,略去了像骆驼一样背负前人遗产的过程,那其“永远重复”洵不能成立。
蓝图上的落差终归只是理念上的区分,在实践场域的分野也未必明晰。譬如当我们追寻文不加点时,在途中涉足挂分,这究竟是伴随着期望的泯灭还是期望的达成?在我们塑造OI的同时,OI也在浇铸我们。既不可否认原生的fst性与衡中牛子性,又承认自己的图景有轻狂的失真,不妨让体验走在言语之前。用不被禁锢的头脑去体味APJifengc的大海与风帆,并效cdsidi,对无法言说之事保持沉默。
用在hzoi上的生活方式体现个体的超越性,保持婞直却又不拘泥于所谓“遗世独立”的单向度形象。这便是LYinMX为我们提供的理想期望范式。生活在hzoi上——始终热爱大地——升上天空。
C.嘉然今天吃什么
区间异或最大值很容易就想到 01-trie
但接下来怎么做比较难想. 观察样例可以发现大部分节点的最大异或值都是整棵树的最大异或值,为什么是这样的,因为假设整棵树由节点 \(x,y\) 贡献最大异或值,那么可以发现除了 \(x,y\) 到根节点路径上的节点取不到 \(x,y\) 两个节点的值,因此就都是整棵树的最大值了. 对于取不到的那部分,因为不是很多,可以考虑直接跑暴力搜一遍
打这个题注意卡空间
#include<bits/stdc++.h>
using namespace std;
int fa[500001],vis[500001];
long long a[500001],b[500001];
int posx,posy;
vector<int>e[500001];
class trie{
public:
int t[25000001][2];
long long to[25000001],cnt=1;
long long maxn=0;
inline void clear(){
for(int i=1;i<=cnt;++i){
t[i][0]=t[i][1]=to[i]=0;
}
cnt=1;
maxn=0;
}
inline void xor_max(int x){
int now=1;
for(int i=59;i>=0;--i){
int res=(a[x]>>i)&1;
if(t[now][res^1]){
now=t[now][res^1];
}
else if(!t[now][res^1] and t[now][res]){
now=t[now][res];
}
else return;
}
if((a[x]^a[to[now]])>maxn){
posx=x;posy=to[now];
maxn=a[x]^a[to[now]];
}
}
inline void insert(int x){
int now=1;
for(int i=59;i>=0;--i){
int res=(a[x]>>i)&1;
if(!t[now][res]){
t[now][res]=++cnt;
}
now=t[now][res];
}
to[now]=x;
}
};
trie tr;
void dfs(int x){
tr.insert(x);tr.xor_max(x);
for(int i:e[x]){
dfs(i);
}
}
void dfs(int now,int last){
if(!now) return;
dfs(fa[now],now);
b[now]=tr.maxn;
vis[now]=true;
tr.insert(now);tr.xor_max(now);
if(now!=last)
for(int i:e[now]){
if(i!=last){
dfs(i);
}
}
}
signed main(){
int n;scanf("%d",&n);
for(int i=2;i<=n;++i){
int x;scanf("%d",&x);
e[x].push_back(i);fa[i]=x;
}
for(int i=1;i<=n;++i){
scanf("%lld",&a[i]);
tr.insert(i);tr.xor_max(i);
}
long long maxn=tr.maxn;
tr.clear();
dfs(posx,posx);
tr.clear();
dfs(posy,posy);
for(int i=1;i<=n;++i){
if(vis[i]){
printf("%lld\n",b[i]);
}
else{
printf("%lld\n",maxn);
}
}
}
D.?
我好想做 APJifengc 小姐的 b20 啊。
可是 APJifengc 小姐说她喜欢的是 b20w,我哭了。
我知道既不是 b20 也不是 b20w 的我为什么要哭的。因为我其实是一只多项式。
我从没奢望 APJifengc 小姐能喜欢自己。我明白的,所有人都喜欢理解余裕上手天才打钱的萌萌的 b20 或者 b20w,没有人会喜欢成天 998244353998244353 没人写的多项式。
但我还是问了 APJifengc 小姐:“我能不能做你的 b20?”
我知道我是注定做不了 b20 的。但如果她喜欢 b20,我就可以一直在身边看着她了,哪怕她怀里抱着的永远都是 b20。
可是她说喜欢的是 b20w。
她现在还在看着我,还在逗我开心,是因为 b20w 还没有出现,只有我这多项式每天蹑手蹑脚地从计数题里爬出来,远远地和她对视。
等她喜欢的 b20w 来了的时候,我就该重新滚回我的题库了吧。
但我还是好喜欢她,她能在我还在她身边的时候多看我几眼吗?
APJifengc 小姐说接下来的每个圣诞夜都要和大家一起过。我不知道大家指哪些人。好希望这个集合能够对我做一次胞吞。
b20w 还在害怕 APJifengc 小姐。
我会去把她爱的 b20w 引来的。
我知道稍有不慎,我就会被薄纱。
那时候 APJifengc 小姐大概会把我的身体好好地装起来扔到门外吧。
那我就成了封装好的多项式,嘻嘻。
我希望她能把我扔得近一点,因为我还是好喜欢她。会一直喜欢下去的。
我的灵魂透过窗户向里面看去,挂着的 NTT 在轻轻鸣响, APJifengc 小姐慵懒地靠在沙发上,表演得非常温顺的 b20w 坐在她的肩膀。壁炉的火光照在她的脸庞,我冻僵的原根在风里微微发烫。
暑假集训CSP提高模拟18的更多相关文章
- 牛客网NOIP赛前集训营-提高组18/9/9 A-中位数
链接:https://www.nowcoder.com/acm/contest/172/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...
- 2015UESTC 暑假集训总结
day1: 考微观经济学去了…… day2: 一开始就看了看一道题目最短的B题,拍了半小时交了上去wa了 感觉自己一定是自己想错了,于是去拍大家都过的A题,十分钟拍完交上去就A了 然后B题写了一发暴力 ...
- 牛客网NOIP赛前集训营-提高组(第四场)游记
牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...
- STL 入门 (17 暑假集训第一周)
快速全排列的函数 头文件<algorithm> next_permutation(a,a+n) ---------------------------------------------- ...
- 20190820 Tue 集训总结&NOIP模拟 27
低谷度过了? 但是skyh阿卡了,还是反衬出我的辣鸡. T1知道要sort,却忘了判重,正解不如暴力分高,555. T2成功化出正解柿子,然后化过头了,化出了无法DP的柿子. 果然不够强,大神们一眼就 ...
- 牛客网NOIP赛前集训营-提高组(第四场)B区间
牛客网NOIP赛前集训营-提高组(第四场)B区间 题目描述 给出一个序列$ a_1 \dots a_n$. 定义一个区间 \([l,r]\) 是好的,当且仅当这个区间中存在一个 \(i\),使得 ...
- 牛客网NOIP赛前集训营-提高组(第四场)B题 区间
牛客网NOIP赛前集训营-提高组(第四场) 题目描述 给出一个序列 a1, ..., an. 定义一个区间 [l,r] 是好的,当且仅当这个区间中存在一个 i,使得 ai 恰好等于 al, al+1, ...
- 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告
目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...
- 暑假集训Day2 互不侵犯(状压dp)
这又是个状压dp (大型自闭现场) 题目大意: 在N*N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. ...
- 暑假集训Day1 整数划分
题目大意: 如何把一个正整数N(N长度<20)划分为M(M>=1)个部分,使这M个部分的乘积最大.N.M从键盘输入,输出最大值及一种划分方式. 输入格式: 第一行一个正整数T(T<= ...
随机推荐
- 如何获取安全获取苹果udid,imei
[点击测试 https://authapi.applekuid.com](https://authapi.applekuid.com/) 目前国内有很多获取udid的方法,例如蒲公英 还有其他的网站都 ...
- 对比`Pinia `和` Vuex`,全面了解` Vue`状态管理
Pinia和Vuex一样都是是vue的全局状态管理器.其实Pinia就是Vuex5,只不过为了尊重原作者的贡献就沿用了这个看起来很甜的名字Pinia. 本文将通过Vue3的形式对两者的不同实现方式进行 ...
- 关于写作那些事之快速上手Mermaid流程图
本文主要介绍了如何快速上手 Mermaid 流程图,不用贴图上传也不用拖拉点拽绘制,基于源码实时渲染流程图,操作简单易上手,广泛被集成于主流编辑器,包括 markdown 写作环境. 通过本节内容你将 ...
- CSP-S提高组数据结构算法模板大合集
CSP-S 算法总结 2.2.1 基础知识与编程环境 无 2.2.2 C++ 程序设计 2 set/nultiset map/multimap deque/priority_queue STL 2.2 ...
- 【SpringSecurity】02 权限控制、自定义登陆、记住我
[资源过滤 权限控制] 就之前的权限问题,例如一个user1登录成功去访问level1的资源当然没有问题 但是页面还呈现了其他权限的资源,比如level2 & level3 既然呈现给了use ...
- Python网络连接request报错:OSError: [Errno 113] No route to host
报错: (pytorch) devil@Monster:~$ huggingface-cli login _| _| _| _| _|_|_| _|_|_| _|_|_| _| _| _|_|_| _ ...
- 【转载】 图解协程调度模型-GMP模型
原文地址: https://www.cnblogs.com/codexiaoyi/p/14975236.html =========================================== ...
- DeepMind Lab的一些python例子—————(Ubuntu22.04系统安装DeepMind Lab)后续
相关资料: Ubuntu22.04系统安装DeepMind Lab ====================================================== 关于DeepMind ...
- JUC高并发编程详细教程
1.大纲 2.课件 https://www.yuque.com/java51/avi/xevuo1 3.视频与代码 1.视频教程 2.视频资料领取,课程代码下载,加微信851298348,发送&quo ...
- .NETCore 服务的三种生命周期
一.接口定义 public interface ITestSerivceSingleton { public string GetServiceNameBase() { return "IT ...