博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA-1611 Crane (构造)
阅读量:4948 次
发布时间:2019-06-11

本文共 1071 字,大约阅读时间需要 3 分钟。

题目大意:给一个1~n的序列,每次操作可以把长度为偶数的序列交换前一半和后一半的位置。求出将这个序列变成升序的步骤。

题目分析:构造求解。

 

代码如下:

# include
# include
# include
# include
# include
using namespace std;int a[10005],pos[10005],n;queue
L,R;void print(int ans){ printf("%d\n",ans); while(!L.empty()){ printf("%d %d\n",L.front(),R.front()); L.pop(),R.pop(); }}void change(int l,int r){ L.push(l),R.push(r); for(int i=l,j=l+(r-l)/2+1;j<=r;++i,++j){ pos[a[i]]=j,pos[a[j]]=i; swap(a[i],a[j]); }}void solve(){ while(!L.empty()) L.pop(); while(!R.empty()) R.pop(); int l=1,ans=0; while(l<=n) { for(int i=l;i<=n;++i){ if(a[i]==i){ ++l; continue; } ++ans; int p=pos[i]; if(2*p-i-1<=n) change(i,2*p-i-1); else{ if((p-i)&1) change(i,p); else change(i+1,p); } if(a[i]==i) ++l; break; } } print(ans);}int main(){ int T; scanf("%d",&T); while(T--) { scanf("%d",&n); for(int i=1;i<=n;++i){ scanf("%d",a+i); pos[a[i]]=i; } solve(); } return 0;}

  

转载于:https://www.cnblogs.com/20143605--pcx/p/4889352.html

你可能感兴趣的文章
四则运算2初步构思
查看>>
Break the Chocolate(规律)
查看>>
C#jbox小节
查看>>
结构体指针释放的问题
查看>>
C#枚举Enum[轉]
查看>>
第三百五十七天 how can I 坚持
查看>>
【动态规划】流水作业调度问题与Johnson法则
查看>>
startActivityForResult不起作用
查看>>
Python&Selenium&Unittest&BeautifuReport 自动化测试并生成HTML自动化测试报告
查看>>
活现被翻转生命
查看>>
POJ 1228
查看>>
SwaggerUI+SpringMVC——构建RestFul API的可视化界面
查看>>
springmvc怎么在启动时自己执行一个线程
查看>>
流操作的规律
查看>>
Python基础学习15--异常的分类与处理
查看>>
javascript运算符的优先级
查看>>
React + Redux 入门(一):抛开 React 学 Redux
查看>>
13位时间戳和时间格式化转换,工具类
查看>>
vue router-link子级返回父级页面
查看>>
C# 通知机制 IObserver<T> 和 IObservable<T>
查看>>