交题:https://cms.ioi-jp.org/documentation

A

给一个序列 a 1 , ⋯ , a n a_1,\cdots,a_n a1​,⋯,an​。
执行 n n n个操作,第 i i i个操作为找出第 i i i个数前离其最近且与它相同的数的位置,把这两个数之间的数全部赋值 a i a_i ai​。求最后的序列。

考虑第 i i i个操作执行完后, i i i之前每个数一定是连续出现正好一段或不出现。

#include<bits/stdc++.h>
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForkD(i,k,n) for(int i=n;i>=k;i--)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Forpiter(x) for(int &p=iter[x];p;p=next[p])
#define Lson (o<<1)
#define Rson ((o<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,0x3f,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define MEMx(a,b) memset(a,b,sizeof(a));
#define INF (0x3f3f3f3f)
#define F (1000000007)
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define vi vector<int>
#define pi pair<int,int>
#define SI(a) ((a).size())
#define Pr(kcase,ans) printf("Case #%d: %lld\n",kcase,ans);
#define PRi(a,n) For(i,n-1) cout<<a[i]<<' '; cout<<a[n]<<endl;
#define PRi2D(a,n,m) For(i,n) { \For(j,m-1) cout<<a[i][j]<<' ';\cout<<a[i][m]<<endl; \}
#pragma comment(linker, "/STACK:102400000,102400000")
#define ALL(x) (x).begin(),(x).end()
#define gmax(a,b) a=max(a,b);
#define gmin(a,b) a=min(a,b);
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{int x=0,f=1; char ch=getchar();while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}return x*f;
}
int a[201000];
map<int,pair<int,int> > h;
int main()
{//  freopen("A.in","r",stdin);
//  freopen(".out","w",stdout);int n=read();For(i,n) a[i]=read(); stack <pair<pair<int,int> , int > > st;For(i,n) {if(st.empty() || !h.count(a[i]) || h[a[i]] ==mp(0,0) ) {st.push(mp(mp(i,i),a[i]));h[a[i]]=mp(i,i);}else {while(!st.empty()) {auto p=st.top();st.pop();if(p.se==a[i]) {h[p.se]=mp(p.fi.fi,i);st.push(mp(h[p.se],a[i]));break;}else {h[p.se]=mp(0,0);}}}}while(!st.empty()) {auto p=st.top();st.pop();Fork(i,p.fi.fi,p.fi.se) a[i]=p.se;}For(i,n) cout<<a[i]<<endl;return 0;
}

B

给 n n n个点对,每个点对 ( x , y ) (x,y) (x,y)可以覆盖 S = ( a , b ) ∣ b < = y , ∣ a − x ∣ < = y − b S={(a,b)|b<=y,|a-x|<=y-b} S=(a,b)∣b<=y,∣a−x∣<=y−b。问取多少个点对能覆盖所有点对。

经典题

#include<bits/stdc++.h>
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForkD(i,k,n) for(int i=n;i>=k;i--)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Forpiter(x) for(int &p=iter[x];p;p=next[p])
#define Lson (o<<1)
#define Rson ((o<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,0x3f,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define MEMx(a,b) memset(a,b,sizeof(a));
#define INF (0x3f3f3f3f)
#define F (1000000007)
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define vi vector<int>
#define pi pair<int,int>
#define SI(a) ((a).size())
#define Pr(kcase,ans) printf("Case #%d: %lld\n",kcase,ans);
#define PRi(a,n) For(i,n-1) cout<<a[i]<<' '; cout<<a[n]<<endl;
#define PRi2D(a,n,m) For(i,n) { \For(j,m-1) cout<<a[i][j]<<' ';\cout<<a[i][m]<<endl; \}
#pragma comment(linker, "/STACK:102400000,102400000")
#define ALL(x) (x).begin(),(x).end()
#define gmax(a,b) a=max(a,b);
#define gmin(a,b) a=min(a,b);
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{int x=0,f=1; char ch=getchar();while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}return x*f;
}
int n;
vector<pair<int,int> > v;
int main()
{//  freopen("B.in","r",stdin);
//  freopen(".out","w",stdout);int n=read();For(i,n) {int a=read(),b=read();v.pb(mp(b-a,a+b));}sort(ALL(v));stack<pair<int,int> > st;   for(int i=0;i<n;i++) {auto now=v[i];while(!st.empty()){auto t=st.top();if(t.fi<=now.fi && t.se <=now.se) {st.pop(); }else break;}st.push(now);}cout<<SI(st)<<endl;return 0;
}

C

考虑n*n的四连通矩阵,每次可以上下左右走一个。
格子上有颜色(黑、白),且只有白色能走。现在你希望令2个白色格子连通。一次操作为把 n ∗ n n*n n∗n的矩阵赋值为白色。问至少几次操作实现目标。

#include<bits/stdc++.h>
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForkD(i,k,n) for(int i=n;i>=k;i--)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Forpiter(x) for(int &p=iter[x];p;p=next[p])
#define Lson (o<<1)
#define Rson ((o<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,0x3f,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define MEMx(a,b) memset(a,b,sizeof(a));
#define INF (0x3f3f3f3f)
#define F (1000000007)
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define vi vector<int>
#define pi pair<int,int>
#define SI(a) ((a).size())
#define Pr(kcase,ans) printf("Case #%d: %lld\n",kcase,ans);
#define PRi(a,n) For(i,n-1) cout<<a[i]<<' '; cout<<a[n]<<endl;
#define PRi2D(a,n,m) For(i,n) { \For(j,m-1) cout<<a[i][j]<<' ';\cout<<a[i][m]<<endl; \}
#pragma comment(linker, "/STACK:102400000,102400000")
#define ALL(x) (x).begin(),(x).end()
#define gmax(a,b) a=max(a,b);
#define gmin(a,b) a=min(a,b);
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{int x=0,f=1; char ch=getchar();while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}return x*f;
}
int r,c,n,sx,sy,tx,ty;
int dir[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
bool inside(int x,int y) {return 1<=x && x<=r &&1<=y &&y<=c;
}
vector<string> a;
bool state(int x,int y){return a[x-1][y-1]=='#';
}
pair<int,int> dis[6000000+10];
int id(int x,int y) {return c*(x-1)+y;
}
void pri(pair<int,int> p) {printf("(%d,%d)",p.fi,p.se);
}
void pri(vector<pair<int,int> > v) {for(auto a:v) {pri(a);cout<<":";int x=a.fi,y=a.se;pri(dis[id(x,y)]);cout<<" ";}cout<<endl;
}
void bfs() {vector<pair<int,int> > q0,qa,qb;int nowdis=0;For(i,r*c) dis[i]=mp(INF,INF);dis[id(sx,sy)]=mp(0,n);q0.pb(mp(sx,sy));while(SI(q0)) {int nxdis=nowdis+1;// relax q0for(int i=0;i<SI(q0);i++) {auto t=q0[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];Rep(di,4) {int nx=x+dir[di][0],ny=y+dir[di][1];if(!inside(nx,ny)) continue;if(dis[id(nx,ny)]!=mp(INF,INF)) continue;int sta=state(nx,ny);if(sta==0) { //whitedis[id(nx,ny)] = now_dis;q0.pb(mp(nx,ny));}}}  // q0 -> qaRep(i,SI(q0)) {qa.pb(q0[i]);}Rep(i,SI(qa)) {auto t=qa[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];Rep(di,2) {int nx=x+dir[di][0],ny=y+dir[di][1];if(!inside(nx,ny)) continue;if(dis[id(nx,ny)]!=mp(INF,INF)) continue;int sta=state(nx,ny);if(now_dis.fi==nowdis) {dis[id(nx,ny)] = mp(nxdis,1);}else if(now_dis.se+1<=n){dis[id(nx,ny)] = mp(nxdis,now_dis.se+1);}else continue;qa.pb(mp(nx,ny));}}//qa -> abRep(i,SI(qa)) {qb.pb(qa[i]);}Rep(i,SI(qb)) {auto t=qb[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];Fork(di,2,3) {int nx=x+dir[di][0],ny=y+dir[di][1];if(!inside(nx,ny)) continue;if(dis[id(nx,ny)]!=mp(INF,INF)) continue;int sta=state(nx,ny);if(now_dis.fi==nowdis) {dis[id(nx,ny)]=mp(nxdis,n+1);}else if(now_dis.fi==nxdis && now_dis.se<n &&  n+1<=2*n ) {dis[id(nx,ny)]=mp(nxdis,n+1);}else if(now_dis.fi==nxdis && now_dis.se==n && n+2<=2*n ) {dis[id(nx,ny)]=mp(nxdis,n+2);}else if(now_dis.fi==nxdis && now_dis.se>n && now_dis.se+1<=2*n ) {dis[id(nx,ny)]=mp(nxdis,now_dis.se+1);}else continue;qb.pb(mp(nx,ny));}}
//
//      cout<<nowdis<<endl;
//      cout<<"q0"<<endl;
//      pri(q0);
//      cout<<"qa"<<endl;
//      pri(qa);
//      cout<<"qb"<<endl;
//      pri(qb);
//      //ab -> qc(q0)q0.resize(0);for(int i=0;i<qb.size();i++) {auto t=qb[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];if(now_dis.fi==nxdis)q0.pb(qb[i]);}qa.resize(0),qb.resize(0);nowdis++;}
//  For(i,r) {//      For(j,c) pri(dis[id(i,j)]),putchar(' ');
//      puts("");
//  }cout<<dis[id(tx,ty)].fi<<endl;}
int main()
{//  freopen("C.in","r",stdin);
//  freopen(".out","w",stdout);cin>>r>>c>>n;
//  For(i,r) For(j,c) cout<<id(i,j)<<' ';cin>>sx>>sy>>tx>>ty;For(i,r) {string s;cin>>s;a.pb(s);}bfs();return 0;
}

D Cat Exercise

给一个 n n n个节点的树,点权 a i a_i ai​。
执行如下操作:

  1. 选取点权最大的点
  2. 删除这个点及其相连的边,若有剩余连通块中取一个,跳回1。否则结束。

问操作1取的点权的和最大值。

The 22nd Japanese Olympiad in Informatics (JOI 2022/2023) Final Round 题解相关推荐

  1. Good Bye 2022: 2023 is NEAR 题解

    Koxia and Whiteboards Statement Kiyora 有nnn块白板,从111 到nnn 编号.初始情况下, 第iii 块白板上写着一个整数aia_iai​ . Koxia 要 ...

  2. Codeforces Round #775 (Div. 2, based on Moscow Open Olympiad in Informatics)简训

    Codeforces Round #775 (Div. 2, based on Moscow Open Olympiad in Informatics)简训 导语 涉及的知识点 题目 A Game B ...

  3. [开源工具]2022/2023免费临时邮箱(Temp Free Mail)

    2022/2023免费临时邮箱Temp Free Mail 1.10分钟邮箱 2.45分钟邮箱 3.60分钟邮箱 4.24小时邮箱 5.5日邮箱 6.其他临时邮箱 7.无时间限制临时邮箱 8.临时邮箱 ...

  4. [开源工具]2022/2023 分享好用的免费的云短信/临时短信[Temp Message]

    [开源工具]2022/2023 分享好用的免费云短信/临时短信[Temp Message] 什么是免费云短信? 免费云短信的优点? 如何使用免费云短信? 国内免费: 国外免费: 为何我输入了虚拟号码却 ...

  5. 2018/2019/2020/2021/2022/2023年度计划阅读书籍(持续更新)

    2018/2019/2020/2021/2022/2023年度计划阅读书籍 1. Java加密与解密的艺术(第二版) 作者:梁栋 在读 2. Spring源码深度解析 作者:郝佳 在读 3. 深入理解 ...

  6. 二维和三维CAD设计Autodesk AutoCAD中文2021/2022/2023

    Autodesk AutoCAD 是全球著名的专业计算机辅助设计软件,用于二维绘图.详细绘制.设计文档和基本三维设计,广泛应用于机械设计.工业制图.工程制图.土木建筑.装饰装潢.服装加工等多个行业领域 ...

  7. FinancesOnline 2022/2023 10大IT趋势预测

    在过去几十年的时间里,全世界的计算能力达到了万亿倍的增长.太空.军事和工业研究促成了范式的转变.与此同时,新冠肺炎大流行等不可预见的事件迫使人们去迎接新的技术,采用与以往不同的技术路径,这导致了IT趋 ...

  8. 宏电亮相中国城镇供水排水协会2022/2023年会暨城镇水务技术与产品交流展示

    2023年4月12日,中国城镇供水排水协会2022/2023年会暨城镇水务技术与产品交流展示在武汉国际博览中心盛大开幕.本届年会聚焦城镇水务行业现状及发展趋势,是围绕行业热点.难点.痛点问题,集行业分 ...

  9. 会声会影2021旗舰版中文版 V24.0.1.260 免费下载 /2022/ 2023专业中文版

    会声会影2021/2022/2023旗舰版是一款非常专业的电脑视频编辑软件.该旗舰版推出全新的2023版本,在功能上基于2022版本有了一个长足的进步,为广大用户提供了上百种滤镜和特效.调控速度.从多 ...

最新文章

  1. python语言标号_Python 编码为什么那么蛋疼?
  2. android gridview滑动卡,Android RecyclerView的卡顿问题
  3. pop3服务器协议初始化失败,Exchange2003系统管理器中的默认POP3 虚拟服务器无法自动启动...
  4. shiro学习(6):shiro连接数据库
  5. 初次注册使用Tushare Pro报错问题
  6. 用计算机运算符编写检索式,检索式
  7. android 滤镜lomo,iOS滤镜实现之LOMO(美图秀秀经典LOMO)(示例代码)
  8. 周鸿祎说:编程能力比马化腾强,不如雷军。你怎么看?
  9. 支撑起SNS的六度分隔理论和150法则
  10. mySQL的备份及导入
  11. SVN强制编写注释才能提交,提交中不允许删除文件操作。
  12. 计算机信息系统打印输出的涉密文件,计算机信息系统打印输出的涉密文件,应当按相应的()文件进行管理。...
  13. html单元格上下拆分代码,在HTML / CSS中如何垂直拆分表格单元格(特殊版本)
  14. Metal 框架之使用 Metal Debugger 查看 GPU 工作负载
  15. oracle 菜单不见了,开始菜单不见了怎么办 开始菜单不见了解决方法【详解】
  16. [半监督学习] Deep Co-Training for Semi-Supervised Image Recognition
  17. java内省的意思_java内省和反射的区别
  18. Overview of Blockchain区块链概述
  19. 答30岁已婚非科班程序员:你的空间一直可以在
  20. python实现气象数据分析_气象数据可视化——利用Python绘制温度平流

热门文章

  1. 农历算法类,含节假日、节气、时令等
  2. 【GAMES103学习笔记】刚体(Rigid Body)
  3. pyzbar+uiautomation(实现扫码进入微信大学习)
  4. HDU 4752 Polygon
  5. python bisect_Python中bisect的用法及示例详解
  6. 【考研】暨南大学848真题与答案 计算机基础综合 830真题与答案 上岸经验贴汇总 信息汇总
  7. Springboot——死信队列 DLX 配置和使用
  8. Brook+ Programming (6)
  9. QT Model/View 编程:MVC模型视图编程:实例实现(二)
  10. PHP 实现全站静态化 首页静态化 列表页静态化 内容静态化 .