洛谷P3516 PRZ-Shift [POI2011] 构造
正解:构造
解题报告:
umm这题就是很思维的?就是想到了就A了想不到就做不出来,然而我也只能是做到理解不知道怎么想出来,,,感觉构造题什么的就很真诚,一点套路也没有,所以像我这种没有脑子只会投机取巧找规律的弱鸡就完全想不到QAQ撑死也不够是能理解解法而已QAQ希望多做一点这类的题目能有帮助趴QAQ
首先嗦嗦这题最基本的变化,就是,假如我现在已经确定了一段[1,i]了,现在要把第i+1放到第i个后面去,假如是酱婶的:balabala 1 2 ... i balabala i+1 balabala(事实上最前面那个balabala是不可能存在的存在也很容易消掉的,但是不要在意这种细节反正没有影响×只是代码有点儿区别注意下就是了qwq
显然的是当[1,i]后面乜有数了并且第i+1个在第一个的时候就能用i个操作a于是就能得到[1,i+1]balabala了,然后一直这么做做做做下去就欧克了
那怎么实现呢,首先用一堆a把第i+1个放到第一个,这儿不难?然后考虑怎么做到把[1,i]之后那些杂七杂八的数都移到前面去并且保持i+1在第一个?其实比较容易想到?就用俩A然后i+1就到了第三位这时候再用个B,i+1就又到第一个了
然后注意一下的是如果到最后i+1在第一个,就直接做;如果在第三个,用一次B然后直接做;如果在第二个呢?当然也不难咯,用两次B就可以了
另外一个需要注意的地方是当解决得差不多了只剩最后两个的时候,如果出现了n,n-1,1,2,...,n-2的情况,按照我们之前的思路,就是用两次B然后就能让n-1到第一位然后就这么顺利地做下去辽
但是!显然这个情况下就不欧克了鸭QAQ因为n被夹到[1,n-2]这个区间里去了就废了
所以考虑换一种变化方式
就是,直接假装n-1在第一个时候的样子移动[1,n-2],不过是当第n个在第三个的时候使用B
这样最后的效果应该就是变成酱婶的:n,1,2,...,n-1
大概能get到?
然后再走n-1次A就欧克了!
然后如果在刚刚说的情况中,n是奇数,辣就是说n-2是奇数,就无法每次都移动俩,所以就无解输出NIE
over!
umm然后放个代码QwQ
#include<bits/stdc++.h>
using namespace std;
#define rp(i,x,y) for(register int i=x;i<=y;++i) const int N=;
int n,a[N],b[N],op[N*N],len[N*N],ans,flag; inline int read()
{
char ch=getchar();int x=;bool y=;
while(ch!='-' && (ch>'' || ch<''))ch=getchar();
if(ch=='-')ch=getchar(),y=;
while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=getchar();
return y?x:-x;
}
void mva(int l){rp(i,,n)b[(i+l)%n]=a[i];b[n]=b[];rp(i,,n)a[i]=b[i];}
void mvb(int &x,int &y,int &z){int tmp=z;z=y,y=x,x=tmp;}
void fd(int i,int &x){rp(j,,n)if(a[j]==i){x=j;return;}}
void final(int x)
{
int w=n+,mva=(n-x)&;
for(int i=x+mva;a[i+]!=;i--)b[--w]=a[i];w=;rp(i,x++mva,n)b[++w]=a[i];
for(int i=;a[i]!=;i++)b[++w]=a[i];rp(i,,n)a[i]=b[i];
if(!mva)return;
rp(i,,n-)b[i+]=a[i];
b[]=a[];b[]=a[],b[]=a[n];
rp(i,,n)a[i]=b[i];
}
void ad(int l,int k)
{
if(op[ans]==k)len[ans]+=l;else len[++ans]=l,op[ans]=k;
if(op[ans]==)len[ans]%=n;else len[ans]%=;
if(!len[ans])--ans;
}
void printans()
{
if(flag){printf("NIE\n");return;}
printf("%d\n",ans);
rp(i,,ans)
{
printf("%d%c",len[i],op[i]+'a'-);
if(i!=ans)printf(" ");
}
}
void dolast()
{
int x;fd(,x);int tt=(n-x+)%n;
if(tt)mva(tt),ad(tt,);
if(a[n-]==n-)return;
if(n&){flag=;return;}
mva(),ad(,);
while(a[n]!=n-){ad(,);mva();ad(,);mvb(a[],a[],a[]);}
ad(n-,);mva(n-);
}
int main()
{
n=read();ans=;flag=;
rp(i,,n)a[i]=read();
rp(i,,n-)
{
int x;fd(i,x);if(x==i)continue;int tt=n-x+;
mva(tt);ad(tt,);fd(i-,x);
rp(k,,(n-x)>>)ad(,),ad(,);
if((n-x)&)ad(,),ad(,);
ad(i-,);final(x);mva(i-);
}
dolast();printans();
}
好难打啊,,,死亡QAQ
洛谷P3516 PRZ-Shift [POI2011] 构造的更多相关文章
- C 洛谷 P3599 Koishi Loves Construction [构造 打表观察]
题目描述 Koishi决定走出幻想乡成为数学大师! Flandre听说她数学学的很好,就给Koishi出了这样一道构造题: Task1:试判断能否构造并构造一个长度为的的排列,满足其个前缀和在模的意义 ...
- 洛谷P1073 Tarjan + 拓扑排序 // 构造分层图
https://www.luogu.org/problemnew/show/P1073 C国有 n n个大城市和 mm 条道路,每条道路连接这 nn个城市中的某两个城市.任意两个城市之间最多只有一条道 ...
- 洛谷P3599 Koishi Loves Construction 构造
正解:构造 解题报告: 传送门! 这题俩问嘛,就分成两个问题港QwQ 就按顺序趴,先港第一问QwQ 首先要发现,n在膜n意义下就是0嘛 那作为前缀和的话显然它就只能放在第一个 然后再想下,发现,如果n ...
- 洛谷P2325王室联邦 SCOI2005 构造+树上分块
正解:构造 解题报告: 照例先放传送门 umm其实我jio得这题应该在教树上莫队的时候港,应该是用来帮助理解树上莫队的分块方式的 然而这题是在学了树上分块之后再遇到的?就显得没那么难了吼 然后就随便说 ...
- 洛谷 P3521 ROT-Tree Rotations [POI2011] 线段树
正解:线段树合并 解题报告: 传送门! 今天学了下线段树合并,,,感觉线段树相关的应用什么的还是挺有趣的,今天晚上可能会整理一下QAQ? 然后直接看这道题 现在考虑对一个节点nw,现在已经分别处理出它 ...
- [洛谷P3527] [POI2011]MET-Meteors
洛谷题目链接:[POI2011]MET-Meteors 题意翻译 Byteotian Interstellar Union有N个成员国.现在它发现了一颗新的星球,这颗星球的轨道被分为M份(第M份和第1 ...
- 洛谷P3513 [POI2011]KON-Conspiracy
洛谷P3513 [POI2011]KON-Conspiracy 题目描述 Byteotia的领土被占领了,国王Byteasar正在打算组织秘密抵抗运动. 国王需要选一些人来进行这场运动,而这些人被分为 ...
- BZOJ2212或洛谷3521 [POI2011]ROT-Tree Rotations
BZOJ原题链接 洛谷原题链接 线段树合并裸题. 因为交换子树只会对子树内部的逆序对产生影响,所以我们计算交换前的逆序对个数和交换后的个数,取\(\min\)即可. 对每个叶子节点建一棵动态开点线段树 ...
- 洛谷P3515 [POI2011]Lightning Conductor(动态规划,决策单调性,单调队列)
洛谷题目传送门 疯狂%%%几个月前就秒了此题的Tyher巨佬 借着这题总结一下决策单调性优化DP吧.蒟蒻觉得用数形结合的思想能够轻松地理解它. 首先,题目要我们求所有的\(p_i\),那么把式子变一下 ...
随机推荐
- 【PHP】解析PHP中的变量
php是一门脚本语言,同时php中的变量类型也是弱语言类型,这和javascript非常相似.笔者在这里说一说PHP中的变量知识点. 1. 引用类型变量 看下面的案例: <?php class ...
- 21.翻译系列:Entity Framework 6 Power Tools【EF 6 Code-First系列】
原文链接:https://www.entityframeworktutorial.net/code-first/entity-framework-power-tools.aspx 大家好,这里就是EF ...
- [转]CentOS6 Linux上安装ss5服务器
本文章转自:http://blog.csdn.net/cuiyifang/article/details/10346239 最后我增加了添加防火墙规则的部分.感谢作者. ss5是常见的socks5 p ...
- 详解Docker的网络模式
我们在使用docker run创建Docker容器时,可以用--net选项指定容器的网络模式,Docker有以下4种网络模式: host模式:使用--net=host指定container模式:使用- ...
- SpringBoot里使用RMI进行远程方法调用
一.Java RMI定义 Java RMI:Java远程方法调用,即Java RMI(Java Remote Method Invocation)是Java编程语言里,一种用于实现远程过程调用的应用程 ...
- electron-vue开发爬坑指南
electron-vue开发遇到的爬坑过程,遇到了以下几种坑: 1:静态资源目录访问不了,想访问放在static目录下的静态资源,使用express指定静态目录访问不到,解决办法:使用electron ...
- sshpass 实现shell脚本直接加载密登录服务器
主要命令:sshpass 这个命不是系统自带的,需要安装: # which sshpass/usr/bin/sshpass[root@666 tools]# rpm -qf /usr/bin/sshp ...
- Fluent动网格【13】:网格光顺总结及实例
光顺(Smoothing)方法是最基本的网格节点更新方法.Fluent提供了三种光顺方法: Spring弹簧光顺 Diffusion扩散光顺 Linearly Elastic Solid光顺 三种方法 ...
- wireshark抓包分析工具的使用
# wireshark抓包分析工具的使用 ## 常用抓包指令 - `ip.src==192.168.60.26 and ip.dst==111.7.187.220 and tcp.port == 80 ...
- 强化学习-MDP(马尔可夫决策过程)算法原理
1. 前言 前面的强化学习基础知识介绍了强化学习中的一些基本元素和整体概念.今天讲解强化学习里面最最基础的MDP(马尔可夫决策过程). 2. MDP定义 MDP是当前强化学习理论推导的基石,通过这套框 ...