BZOJ 3990 [SDOI2015]排序 ——搜索
【题目分析】
可以发现,操作的先后顺序是不影响结果的,那么答案就是n!的和。
可以从小的步骤开始搜索,使得每一个当前最小的块都是上升的数列,然后看看是否可行即可。
复杂度好像是4^n
【代码】(哪里写挂了,意会一下就好了)
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib> #include <map>
#include <set>
#include <queue>
#include <string>
#include <iostream>
#include <algorithm> using namespace std; #define maxn 5005
#define ll long long
#define mlog 15
#define inf 0x3f3f3f3f
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i) void Finout()
{
#ifndef ONLINE_JUDGE
freopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
#endif
} int Getint()
{
int x=0,f=1; char ch=getchar();
while (ch<'0'||ch>'9') {if (ch=='-') f=-1; ch=getchar();}
while (ch>='0'&&ch<='9') {x=x*10+ch-'0'; ch=getchar();}
return x*f;
} int a[mlog][maxn],b[maxn],n,cnt=0,s;
ll ans=0;
ll fac[mlog]; void solve(int now,int n)
{
if (n==1)
{
ans+=fac[s];
return ;
}
int cnt=0;
int pos1=0,pos2=0;
for (int i=1;i<=n;i+=2)
{
if (a[now][i]>a[now][i+1])
{
cnt++;
if (!pos1) pos1=i;
else pos2=i;
}
if (cnt>2) return ;
}
if (cnt==0)
{
for (int i=1;i<=n/2;++i)
a[now+1][i]=(a[now][i*2-1]+1)/2;
solve(now+1,n/2);
}
else
{
if (cnt==1)
{
swap(a[now][pos1],a[now][pos1+1]);
s++;
for (int i=1;i<=n/2;++i)
a[now+1][i]=(a[now][i*2-1]+1)/2;
solve(now+1,n/2);
s--;
swap(a[now][pos1],a[now][pos1+1]);
}
else
{
swap(a[now][pos1],a[now][pos2]);
if (a[now][pos1]<a[now][pos1+1]&&a[now][pos2]<a[now][pos2+1])
{
s++;
for (int i=1;i<=n/2;++i)
a[now+1][i]=(a[now][i*2-1]+1)/2;
solve(now+1,n/2);
s--;
}
swap(a[now][pos1],a[now][pos2]); swap(a[now][pos1+1],a[now][pos2]);
if (a[now][pos1]<a[now][pos1+1]&&a[now][pos2]<a[now][pos2+1])
{
s++;
for (int i=1;i<=n/2;++i)
a[now+1][i]=(a[now][i*2-1]+1)/2;
solve(now+1,n/2);
s--;
}
swap(a[now][pos1+1],a[now][pos2]); swap(a[now][pos1],a[now][pos2+1]);
if (a[now][pos1]<a[now][pos1+1]&&a[now][pos2]<a[now][pos2+1])
{
s++;
for (int i=1;i<=n/2;++i)
a[now+1][i]=(a[now][i*2-1]+1)/2;
solve(now+1,n/2);
s--;
}
swap(a[now][pos1],a[now][pos2+1]); swap(a[now][pos1+1],a[now][pos2+1]);
if (a[now][pos1]<a[now][pos1+1]&&a[now][pos2]<a[now][pos2+1])
{
s++;
for (int i=1;i<=n/2;++i)
a[now+1][i]=(a[now][i*2-1]+1)/2;
solve(now+1,n/2);
s--;
}
swap(a[now][pos1+1],a[now][pos2+1]);
}
}
return ;
} int main()
{
Finout();
n=Getint();
n=1<<n;
fac[0]=1;
F(i,1,12) fac[i]=fac[i-1]*i;
F(i,1,n) a[1][i]=Getint();
solve(1,n);
cout<<ans<<endl;
}
BZOJ 3990 [SDOI2015]排序 ——搜索的更多相关文章
- BZOJ 3990: [SDOI2015]排序 [搜索]
3990: [SDOI2015]排序 题意:\(2^n\)的一个排列,给你n种操作,第i种把每\(2^{i-1}\)个数看成一段,交换任意两段.问是这个序列有序的操作方案数,两个操作序列不同,当且仅当 ...
- BZOJ.3990.[SDOI2015]排序(DFS)
题目链接 操作序列的顺序显然是无关的,所以只需按特定顺序求出一个长度为\(l\)的操作序列,它对答案的贡献为\(l!\). 我们从小到大枚举所有选择.若当前为第\(i\)个,如果有一段长度为\(2^i ...
- BZOJ 3990 [SDOI2015]排序
题解: 首先很容易看出各个操作是互不影响的,即对于一个合法的操作序列,我们可以任意交换两个操作的位置而不影响合法性. 因此我们可以忽略操作先后的影响,只考虑这个操作是否会出现在操作序列中. 如果用2n ...
- [bzoj3990][SDOI2015]排序-搜索
Brief Description 小A有一个1-2^N的排列A[1..2^N],他希望将A数组从小到大排序,小A可以执行的操作有N种,每种操作最多可以执行一次,对于所有的i(1<=i<= ...
- 【搜索】BZOJ 3990: 【Sdoi 2015】排序
3990: [SDOI2015]排序 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 336 Solved: 164[Submit][Status][ ...
- [BZOJ3990][SDOI2015]排序(DFS)
3990: [SDOI2015]排序 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 902 Solved: 463[Submit][Status][ ...
- BZOJ 3990: [SDOI2015]排序(搜索+剪枝)
[SDOI2015]排序 Description 小A有一个1-2^N的排列A[1..2^N],他希望将A数组从小到大排序,小A可以执行的操作有N种,每种操作最多可以执行一次,对于所有的i(1< ...
- 006-筛选分类排序搜索查找Filter-Classificatio-Sort-Search-Find-Seek-Locate
006-筛选分类排序搜索查找Filter-Classificatio-Sort-Search-Find-Seek-Locate https://www.cnblogs.com/delphixx/p/1 ...
- bzoj 3991: [SDOI2015]寻宝游戏 虚树 set
目录 题目链接 题解 代码 题目链接 bzoj 3991: [SDOI2015]寻宝游戏 题解 发现每次答案就是把虚树上的路径*2 接在同一关键点上的点的dfs序是相邻的 那么用set动态维护dfs序 ...
随机推荐
- 转:android 屏幕适配小结
做android开发,开源嘛,满市场都是凌乱的机型,总少不了适配这样或那样的型号.在这里分享一下自己在开发中用到的方法. 首先要介绍一下drawable-mdpi.drawable-hdpi-1280 ...
- [Ubuntu]“ubuntu.sh: 113: ubuntu.sh:Syntax error: "(" unexpected ”报错解决方法
原因:有可能是兼容性问题 解决方法: 1.sudo dpkg-reconfigure dash 2.在弹出的窗口选择no
- Node.js 打造实时多人游戏框架
在 Node.js 如火如荼发展的今天,我们已经可以用它来做各种各样的事情.前段时间UP主参加了极客松活动,在这次活动中我们意在做出一款让“低头族”能够更多交流的游戏,核心功能便是 Lan Party ...
- C++和ASM文件的互相调用
1. C++调用ASM中的函数,需要在ASM源文件中指定.model flat, c 就是指定以C的形式编译,然后在头文件中用EXTERN_C声明这个头文件就可以了 2. ASM中调用C++函数,需要 ...
- (九)mybatis之生命周期
生命周期 SqlSessionFactoryBuilder SqlSessionFactoryBuilder的作用就是生成SqlSessionFactory对象,是一个构建器.所以我们一旦构建 ...
- 融云参加RTC实时互联网大会 现场集成IM SDK
9月21至22日,由全球实时云服务商声网Agora.io主办的RTC2017实时互联网大会在北京万豪酒店成功举办.作为亚洲最权威的RTC实时通信行业技术盛会,会议吸引了来自全球上千名开发者参加,Goo ...
- 访问修饰符(C# 参考)
第一篇 就抄写了一下下MSDN上面的东西练练手吧!!! 访问修饰符是一些关键字,用于指定声明的成员或类型的可访问性. 本节介绍四个访问修饰符: public protected ...
- Luogu P4609 [FJOI2016]建筑师&&CF 960G Bandit Blues
考虑转化题意,我们发现其实就是找一个长度为\(n\)的全排列,使得这个排列有\(A\)个前缀最大值,\(B\)个后缀最大值,求方案数 我们考虑把最大值拎出来单独考虑,同时定义一些数的顺序排列为单调块( ...
- readystatechange
// alternative to DOMContentLoaded document.onreadystatechange = function () { if (document.readySta ...
- hash 散列表
一个字符串的hash值: •现在我们希望找到一个hash函数,使得每一个字符串都能够映射到一个整数上 •比如hash[i]=(hash[i-1]*p+idx(s[i]))%mod •字符串:abc,b ...