news 2026/6/10 8:10:59

Codeforces Round 1069 (Div. 2)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Codeforces Round 1069 (Div. 2)

A. Little Fairy’s Painting

ideas:

我感觉题目一点都不好读懂
题目的意思是:要去填充1e181e^{18}1e18个格子,有无限种颜色,给出n个,找规律去填充后面的。
比如案例三:
58 10 15 20 25 5 \\ 8\ 10\ 15\ 20\ 25 \\5810152025
第0个位置的颜色数是8,第一个是10,这样不同的颜色数就是2,每一个数代表不同的颜色,这个案例中就是有5个不同颜色的数。此时第n+1位就填5,此时不同颜色数增加到6(因为5不再原来的数组中)。
后续填充的规则是:不同颜色数作为颜色编号。
那么当,不同颜色数等于前n位颜色编号中的某一位时,不同颜色数就不再增加,答案也就因此固定。

code:

intn;cin>>n;set<int>st;for(inti=0;i<n;i++){cin>>a[i];st.insert(a[i]);}intk=st.size();intans=INT_MAX;for(inti=0;i<n;i++){if(a[i]>=k)ans=min(ans,a[i]);}cout<<ans<<endl;

B. XOR Array

ideas:

题目含义是:
1.在l−rl-rlr这个区间内的XOR的结果为0;
2.在l−rl-rlr这个区间外的XOR的结果不为0。
结论:
a[l]⊕a[l+1]⊕...⊕a[r]=pre[r]⊕pre[l−1]a[l] ⊕ a[l+1] ⊕ ... ⊕ a[r] = pre[r] ⊕ pre[l-1]a[l]a[l+1]...a[r]=pre[r]pre[l1]

推导:
a1⊕a2⊕a3....⊕al....⊕ar=pre[r]a_1\oplus a_2 \oplus a_3.... \oplus a_l.... \oplus a_r = pre[r]a1a2a3....al....ar=pre[r]
a1⊕a2⊕a3....⊕al=pre[l]a_1\oplus a_2 \oplus a_3.... \oplus a_l = pre[l]a1a2a3....al=pre[l]
根据异或的性质:
a⊕a=0a\oplus a = 0aa=0
很轻易得出上面的结论。

要想到答案为0,得出:
pre[r]=pre[l−1]pre[r] = pre[l-1]pre[r]=pre[l1]

于是我们可以得出构造方法:
1.只需要pre[r]=pre[l−1]pre[r] = pre[l-1]pre[r]=pre[l1]
2.其他位置的任意,我们选择pre[i]=ipre[i]=ipre[i]=i
3.我们构造的a[i]a[i]a[i]数组是前缀异或值,反解计算出每一位的值。

code:

intn,l,r;cin>>n>>l>>r;vector<int>pre(n+2);for(inti=0;i<n+2;i++)pre[i]=i;pre[l-1]=pre[r];for(inti=0;i<n;i++){cout<<(pre[i]^pre[i+1])<<" ";}cout<<endl;

C. Needle in a Haystack

ideas:

一个模拟题。
思路是:
1.可行性检查:
如果长度一样,一个字符t中没有就输出"Impossible"
如果有一个字符的次数,t中不够,就输出"Impossible"
2.分离字符:
把s中的每一个字符分离出来,剩下的字符串排序
3.合并字符:
对于每一个s中的字符,找到合适的位置放进去就可以
最后把剩余的字符加进去。

code:

string s,t;cin>>s>>t;map<char,int>mpa,mpb;for(autoc:s)mpa[c]++;for(autoc:t)mpb[c]++;//可行性检查for(autoc:s){if(mpb[c]<mpa[c]){cout<<"Impossible"<<endl;return;}}//分离字符string tmp="";for(charc='a';c<='z';c++){intd=mpb[c]-mpa[c];tmp+=string(d,c);}sort(tmp.begin(),tmp.end());//合并字符string ans="";intpos=0;for(autoc:s){while(pos<tmp.size()&&tmp[pos]<c){ans+=tmp[pos];pos++;}ans+=c;}while(pos<tmp.size()){ans+=tmp[pos];pos++;}cout<<ans<<endl;
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 2:05:57

EmotiVoice相信真实的人际关系不可复制

EmotiVoice&#xff1a;当技术学会“共情” 在智能语音助手回答“我很难过”时只回一句“抱歉听到这个”&#xff0c;我们是否曾期待它能真正理解那份低落&#xff1f;在有声书里&#xff0c;旁白用毫无波澜的语调念出“他颤抖着说出最后一句话”&#xff0c;听众却感受不到一…

作者头像 李华
网站建设 2026/6/9 21:24:39

Boltz-2生物分子结构预测工具:5分钟快速安装指南

Boltz-2生物分子结构预测工具&#xff1a;5分钟快速安装指南 【免费下载链接】boltz Official repository for the Boltz-1 biomolecular interaction model 项目地址: https://gitcode.com/GitHub_Trending/bo/boltz 想要在药物发现和生物分子研究中获得准确的结构预测…

作者头像 李华
网站建设 2026/6/9 3:06:08

24、量子信息理论中的信息、非物质主义与计算加速来源解析

量子信息理论中的信息、非物质主义与计算加速来源解析 量子基础原理的困境 在探讨量子相关理论时,基础原理面临着诸多挑战。例如,虽然存在实验问题,但现有理论并未解释其存在的原因。以纠缠现象为例,为什么并非所有实验问题的真值赋值都能像经典情况那样,简化为关于个体…

作者头像 李华
网站建设 2026/6/6 18:15:57

终极指南:使用Syncthing Tray轻松管理您的文件同步

终极指南&#xff1a;使用Syncthing Tray轻松管理您的文件同步 【免费下载链接】syncthingtray Tray application and Dolphin/Plasma integration for Syncthing 项目地址: https://gitcode.com/gh_mirrors/sy/syncthingtray 在当今多设备时代&#xff0c;文件同步已成…

作者头像 李华
网站建设 2026/6/10 6:21:04

EmotiVoice赋能传统家电智能化升级

EmotiVoice赋能传统家电智能化升级 在智能音箱早已走进千家万户的今天&#xff0c;人们开始追问&#xff1a;为什么家里的冰箱、空调、洗衣机还只能“滴滴”两声报警&#xff1f;当语音助手能在深夜轻声安慰情绪低落的用户时&#xff0c;我们的家电是否也能学会“温柔提醒”而不…

作者头像 李华
网站建设 2026/6/2 14:09:36

【光照】[PBR][几何遮蔽]实现方法对比

几何遮蔽的基本流程几何遮蔽(G)在BRDF中用于模拟微表面间的自阴影和遮蔽效应&#xff0c;其计算流程通常分为三个步骤&#xff1a;‌遮蔽项计算‌&#xff1a;光线入射方向的遮挡概率‌阴影项计算‌&#xff1a;视线方向的遮挡概率‌联合计算‌&#xff1a;将两者结合形成完整的…

作者头像 李华