当前位置: 首页 > news >正文

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;
http://www.cnnetsun.cn/news/119000.html

相关文章:

  • CCM CRM单相有源功率因数校正boost PFC电路仿真探索
  • 使用EmotiVoice避免版权纠纷的正确姿势
  • 有声内容创作者福音:EmotiVoice一键生成带情绪的朗读音频
  • Java中PageHelper的拦截器实现机制
  • 为什么EmotiVoice成为开发者最青睐的开源TTS引擎?
  • 18、量子测量、信息增益与量子信息理论的哲学思考
  • 26、量子计算、力学与密码学深度解析
  • Nginx gzip压缩完整配置指南:如何快速提升网站性能
  • [深度学习] 大模型学习5-高效微调框架Unsloth使用指北
  • WIndows安装MongoDB数据库
  • NiceGUI之Button操作(ElementPlus组件库)
  • Claude code学习笔记(一)-环境安装claude code+ccr
  • WordPress中文完全教程:从菜鸟到神人的终极指南
  • EmotiVoice语音合成引擎的更新日志与版本迭代规划
  • 纪念日回忆录语音生成:温情科技应用
  • Flutter富文本渲染性能优化终极指南:长文本处理与资源回收策略
  • Ditto剪贴板管理器架构深度解析:从用户痛点到技术实现
  • Qwen3-4B终极指南:如何快速上手新一代AI语言模型
  • 5 款 AI 写论文哪个好?深度横评后,才发现虎贲等考 AI 是学术圈隐藏的 “六边形战士”!
  • EmotiVoice vs 传统TTS:情感表达能力的代际差异分析
  • POV-Ray 光线追踪终极指南:从零开始掌握专业渲染
  • EmotiVoice支持语音情感风格迁移学习
  • 定期第三方安全审计:EmotiVoice质量保证
  • 不同职业人群对EmotiVoice的应用需求分析
  • 手机系统预装应用包彻底删除
  • EmotiVoice能否实现多人对话同步生成?技术可行性评估
  • FusionCompute 8.0 实验环境搭建:完整资源获取与部署指南
  • AI主播直播间搭建:EmotiVoice语音部分实现
  • 静态代码扫描服务 100分(python、java、c++、js、c
  • Directus周起始日难题:3步从周日切换到周一的技术解决方案