长为n(n<=2e5)的数组a,ai在[1,m)(m<=2e5)范围内,
初始时,有数组b,bi=i,
对于k=1,2,...,n,分别独立的对b数组执行不包含k的交换(b[ai],b[ai+1])的操作:
例如,n=5,k=3,则需要对[1,3)∪(3,5]执行操作,
初始时bi=i,随后,
交换(b[a1],b[a1+1]),交换(b[a2],b[a2+1]),
交换(b[a4,b[a4+1]),交换(b[a5],b[a5+1])
交换后,找到1数值所在的位置,记为Sk,
对于k=1,2,...,n,分别输出Sk的答案
aging佬代码
注意到交换操作是可结合的、可逆的
哪个位置经历[i,n]步后换到位置j,可以通过位置j倒序执行[i,n]操作得到
所以可以先顺序执行一遍,顺序交换,pos记录值当前所在的位置,
to[i]表示值0在经历了前i步交换后当前的位置
然后考虑倒序回滚操作,将前缀、后缀拼接起来
- #include
- using namespace std;
- const int N=2e5+10;
- int n,m,a[N],b[N],pos[N],to[N],ans[N];
- int main(){
- scanf("%d%d",&m,&n);
- for(int i=0;i
- scanf("%d",&a[i]);
- a[i]--;
- }
- for(int i=0;i
- b[i]=pos[i]=i;
- }
- for(int i=0;i
- swap(pos[b[a[i]]],pos[b[a[i]+1]]);
- swap(b[a[i]],b[a[i]+1]);
- to[i]=pos[0];
- }
- for(int i=0;i
- b[i]=i;
- }
- for(int i=n-1;i>=0;--i){
- int now=(i-1>=0?to[i-1]:0);
- ans[i]=b[now];
- swap(b[a[i]],b[a[i]+1]);
- }
- for(int i=0;i
- printf("%d\n",1+ans[i]);
- }
- return 0;
- }
-
相关阅读:
K8S V1.23 安装--Kubeadm+contained+公网 IP 多节点部署
【023】Springboot+vue+mysql员工考勤管理系统(多角色登录、请假、打卡)(含源码、数据库、运行教程)
黑炫酷的监控界面,实际上是用了什么开源工具?
【QT+QGIS跨平台编译】之六十四:【QGIS_CORE跨平台编译】—【错误处理:未定义类型QTemporaryDir - QgsSourceCache】
【云计算知识库】什么是云?什么是云计算?计算的是什么?openstack是什么?nova计算组件?【持续更新中】
springboot/ssm甘肃印象网站Java地区特产文化交流管理系统web
计算机视觉入门-纹理表示、平均表示法、Mean Shift、图像分割
SpringBean生命周期&扩展接口&简化配置
es笔记三之term,match,match_phrase 等查询方法介绍
LoadingCache
-
原文地址:https://blog.csdn.net/Code92007/article/details/128062414