手速局,因为水平不够三题遗憾离场。

A. Meaning Mean

题意

你一个序列,你每次可以选择两个数删掉,并把他们的平均数加入到序列的末尾。当序列长度为 \(1\) 的时候,剩下的数最大值是多少。

思路

当时比赛的时候唐了,耽误了好几分钟。想的是先奇数和奇数相加,偶数和偶数相加,这样能避免下取整的时候 \(-1\) 。其实每次选择序列里两个最小的数操作就可以了,因为每次操作相当于把两个数除 \(2\) ,所以尽量的让大数除的少就能保证最后剩下的数最大。

代码

void solve()
{
int n;
cin>>n;
priority_queue<int,vector<int>,greater<int>> q;
for(int i=1;i<=n;i++)
{
int x;
cin>>x;
q.push(x);
}
while(q.size()!=1)
{
int x=q.top();q.pop();
int y=q.top();q.pop();
q.push((x+y)/2);
}
cout<<q.top()<<endl;
}

B. Maximize Mex

题意

给你一个序列和一个 \(x\) ,你可以进行任意次操作令 \(a_i:=a_i+x\) 。问你以最优方式操作序列的 \(MEX\) 最大是多少。

题意

一般求 \(MEX\) 我都会开个桶来记录一下每个数出现了多少次,从小到大遍历第一个没有出现的数就是 \(MEX\) 。这个题也是同理,如果有多个相同的数那么只有一个数能产生贡献,然后让剩下的都加上 \(x\) 即可。

代码

void solve()
{
int n,m;
cin>>n>>m;
vector<int> num(n+2);
for(int i=1;i<=n;i++)
{
int x;cin>>x;
if(x>n) continue;
num[x]++;
}
for(int i=0;i<=n+1;i++)
{
if(!num[i]) {cout<<i<<endl;return;}
num[i]--;
if(i+m<=n) num[i+m]+=num[i];
num[i]=0;
}
}

C1. Adjust The Presentation (Easy Version)

题意

给你一个长度为 \(n\) 的操作者的顺序 \(a\),再给你一个长度为 \(m\) 规定了只能由谁操作的物品的顺序 \(b\) 。每个操作者操作完一次之后可以插入到队列中的任何位置。问你这 \(m\) 个物品能不能被对应的操作者操作完成。

思路

首先一个人如果操作完了它可以插入到队列的任何位置,说明他已经无敌了,如果当前被操作的物品指定的操作者排在后面并且他没有操作过任何物品,那么他无论如何也无法排到前面来操作,这个序列就不合法。如果这个物品对应的操作者已经操作过了,由于他可以去任何位置,那么这个物品就能立刻被操作。如果所有的物品都能被操作那这个序列就合法。

代码

using namespace std;
void solve()
{
int n,m,q;
cin>>n>>m>>q;
vector<int> a(n+1),b(m+1);
vector<int> vis(n+1);
for(int i=1;i<=n;i++) cin>>a[i];
for(int i=1;i<=m;i++) cin>>b[i];
int pos=1;
for(int i=1;i<=m;i++)
{ if(vis[b[i]]) continue;
else if(a[pos]==b[i])
{
vis[a[pos]]=1;
pos++;
continue;
}
else {cout<<"TIDAK\n";return;}
}
cout<<"YA\n";
}

C2. Adjust The Presentation (Hard Version)

题意

在 \(\text{C1}\) 的基础上又添加了一个修改的操作。我有 \(q\) 次修改操作,每次修改可以更换一个物品指定的操作者(永久性操作),问你修改完了之后的序列是否还合法。

思路

如果一个人可以随意调换位置 (无敌了) 说明他已经操作过物品了,那么他最早能调换位置的时间就是第一个指定他为操作者物品的下标,即第一个 \(b_j=i\) 的下标 \(j\) 。那么每个人最早的无敌时间不能早于排在他前面的人的无敌时间。现在问题是怎么维护这个最早的无敌时间。

我们每次修改只会修改一个位置,那么他能影响到的之后他前面的位置,后面的位置和他自己。所以每次修改只需要更新这三个位置就行了。

代码

void solve()
{
int n,m,q,num=0;
cin>>n>>m>>q;
vector<int> a(n+1),b(m+1),inv(n+1),s(n+1);
vector<set<int>> times(n+1);//维护每个人最早无敌时间
for(int i=1;i<=n;i++) cin>>a[i],inv[a[i]]=i;
for(int i=1;i<=m;i++)
{
cin>>b[i];
b[i]=inv[b[i]];
times[b[i]].insert(i);
}
for(int i=1;i<=n;i++)
{
s[i]=times[i].empty()?m+1:*times[i].begin();//如果没有指定他操作的物品,那这个人的无敌时间就是正无穷
}
for(int i=1;i<n;i++) if(s[i]>s[i+1]) num++;//统计不合法的人的个数
if(num) cout<<"TIDAK\n";
else cout<<"YA\n"; auto update=[&](int x,int c)
{
if(c==1) s[x]=times[x].empty()?m+1:*times[x].begin();
if(x>1 && s[x-1]>s[x]) num+=c;
if(x<n && s[x]>s[x+1]) num+=c;
}; while(q--)
{
int x,y;cin>>x>>y;
y=inv[y];
update(b[x],-1);//删掉这个位置的贡献
times[b[x]].erase(x);
update(b[x],1);//删掉之后更新无敌时间和不合法位置的个数
b[x]=y;//修改
update(b[x],-1);
times[b[x]].insert(x);
update(b[x],1);
if(num) cout<<"TIDAK\n";
else cout<<"YA\n";
}
}

Codeforces Round 977 (Div. 2)的更多相关文章

  1. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  2. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  3. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  4. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  5. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  6. Codeforces Round #262 (Div. 2) 1003

    Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...

  7. Codeforces Round #262 (Div. 2) 1004

    Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...

  8. Codeforces Round #371 (Div. 1)

    A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...

  9. Codeforces Round #268 (Div. 2) ABCD

    CF469 Codeforces Round #268 (Div. 2) http://codeforces.com/contest/469 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...

  10. 贪心+模拟 Codeforces Round #288 (Div. 2) C. Anya and Ghosts

    题目传送门 /* 贪心 + 模拟:首先,如果蜡烛的燃烧时间小于最少需要点燃的蜡烛数一定是-1(蜡烛是1秒点一支), num[g[i]]记录每个鬼访问时已点燃的蜡烛数,若不够,tmp为还需要的蜡烛数, ...

随机推荐

  1. nacos启动失败:No DataSource set

    通过docker查看nacos的日志发现nacos好端端的突然不能用了 docker logs nacos 报错后说是no datasource set,我看了我在docker里的MySQL是正常启动 ...

  2. faster-fifo:C++实现的python多进程通信队列 —— 强化学习ppo算法库sample-factory的C++实现的python多进程通信队列 —— python3.12版本下成功通过测试

    项目地址: https://github.com/alex-petrenko/faster-fifo 需要注意,该项目给出了两种安装方法,一种是pip从pypi官网安装,一种是从GitHub上的源码安 ...

  3. 图床、云对象存储、CDN业务:“自定义 CDN 加速域名” 与 “自定义源站域名” 的区别

    参考: https://developer.qiniu.com/kodo/8622/dev-the-binding-source-domain-name ----------------------- ...

  4. python 中 ctypes 的使用尝试

    最近在看Python的性能优化方面的文章,突然想起ctypes这个模块,对于这个模块一直不是很理解,不过再次看完相关资料有了些新的观点. ctypes 这个模块个人观点就是提供一个Python类型与C ...

  5. 再探 游戏 《 2048 》 —— AI方法—— 缘起、缘灭(2) —— 游戏环境设计篇

    注意: 本文为前文 再探 游戏 < 2048 > -- AI方法-- 缘起.缘灭(1) -- Firefox浏览器自动运行篇 接续篇. ========================== ...

  6. FAT32和NTFS文件系统的区别

    文件系统对于在计算设备上运行至关重要. 因此,选择正确的文件系统变得很重要. FAT32 和 NTFS 是两个具有显着差异的文件系统. 1.磁盘分区容量区别 NTFS可以支持的分区(如果采用动态磁盘则 ...

  7. TL431

    1. 设置分流电压VKA 由于分流电压调节器是非理想的: 存在动态电阻ZKA,会导致VREF存在一个偏置电压: ( IKA - INOM ) × ZKA 其中,INOM 是 VKA = VREF 测试 ...

  8. JavaScript设计模式样例十二 —— 享元模式

    享元模式(Flyweight Pattern) 定义:减少创建对象的数量,以减少内存占用和提高性能.目的:用共享技术有效地支持大量细粒度的对象.场景:系统中有大量对象. // 构建享元对象 class ...

  9. kafka消费者处理能力低引起rebalance分析

    一.背景介绍 项目上进行算法调度的需求,打算采用kafka作为消息中间件,通过将多个算法消费者加入到同一个group中并行的处理算法请求,从而达到高效处理的目的.但是算法处理的时间较长,多则几十分钟, ...

  10. SRE 必备知识 - Kafka 探秘之零拷贝技术

    如果你了解过 Kafka,那么它用到的一个性能优化技术可能会引起你的注意 -- 操作系统的零拷贝(zero-copy)优化. 零拷贝操作可以避免对数据的非必要拷贝,当然,并非是说完全没有拷贝. 在 K ...