先证明把每次i放到i位置最后次数最少:感觉,可以,用归纳法?

//在序列后再加一个相同的序列,就可以模拟用各个数字开头的情况了
每个位置不对的只需要换一次
54123 ,5固定->41235变成12345

任何一个数固定不变,都相当于从这种情况对应的1所在的位置开始排一遍12345.(例如54123 ,5固定->41235变成12345)所以只需要每个位置开始都判断变成12345所需步数即可

把输入倒过来看,变成12345就相当于正着变成54321 (这个对称很巧妙啊),可以模块化

#include <cstdio>
#include <algorithm>
using namespace std; int cal(int A[], int N) { //54123—>12345可以看做12354->12345所以每个位置开始都判断变成12345所需步数即可
int cnt = , vis[] = {};
for (int i = ; i <= N; i++) //cnt统计不用换位的个数;不用换位的A[j]就等于j,进入下一个数了
if(!vis[i]) { //某个数还没到正确位置
cnt++;
for (int j = i; !vis[j]; j = A[j]) //这个循环中一直换位直到不用换
vis[j] = ;
}
return N - cnt;
} int main() {
int N, A[], B[];
while (scanf("%d", &N), N) {
for (int i = ; i <= N; i++) {
scanf("%d", &A[i]);
B[N - i + ] = B[ * N - i + ] = A[i + N] = A[i];
} int ans = << ;
for (int i = ; i < N; i++)
ans = min(ans, cal(A + i, N)); for (int i = ; i < N; i++)
ans = min(ans, cal(B + i, N)); printf("%d\n", ans);
} return ;
} #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; const int N = ;
int p[N],k[N],w[N];
int f[N],n; int solve(int s, int d) {
int cnt = ;
for(int i = ; i <= n; i++) {
if(k[i] != s) {
cnt++;
k[w[s]] = k[i];
w[k[i]] = w[s];
k[i] = s;
w[s] = i;
}
s += d;
if(s > n)
s = ;
if(s <= )
s = n;
}
return cnt;
}
int main() {
while(scanf("%d",&n) && n) {
for(int i = ; i <= n; i++) {
scanf("%d",&p[i]);
f[p[i]] = i;
}
int Min = 0x3f3f3f3f;
for(int i = ; i <= n; i++) {
memcpy(k, p, sizeof(p));
memcpy(w, f, sizeof(f));
Min = min(Min, solve(i,-));
memcpy(k, p, sizeof(p));
memcpy(w, f, sizeof(f));
Min = min(Min, solve(i,));
}
printf("%d\n",Min);
}
}

uva10570 Meeting with Aliens的更多相关文章

  1. UVA-10570 Meeting with Aliens (枚举+贪心)

    题目大意:将一个1~n的环形排列变成升序的,最少需要几次操作?每次操作可以交换任意两个数字. 题目分析:枚举出1的位置.贪心策略:每次操作都保证至少一个数字交换到正确位置上. # include< ...

  2. UVA 10570 Meeting with Aliens

    题意: N个外星人围成一桌坐下,有序的排列指N在N-1与N+1中间,现在给出一个序列,问至少交换几次可以得到有序的序列. 分析: 复制一遍输入序列,放在原序列之后.相当于环.通过枚举,可以把最小交换次 ...

  3. UVa 10570 Meeting with Aliens (暴力)

    题意:给定一个排列,每次可交换两个数,用最少的次数把它变成一个1~n的环状排列. 析:暴力题.很容易想到,把所有的情况都算一下,然后再选出次数最少的那一个,也就是说,我们把所有的可能的形成环状排列全算 ...

  4. UVA - 10570 Meeting with Aliens (置换的循环节)

    给出一个长度不超过500的环状排列,每次操作可以交换任意两个数,求把这个排列变成有序的环状排列所需的最小操作次数. 首先把环状排列的起点固定使其成为链状排列a,枚举排好序时的状态b(一种有2n种可能) ...

  5. UVA 10570 Meeting with Aliens 外星人聚会

    题意:给你一个排列,每次可以交换两个整数(不一定要相邻),求最少交换次数把排列变成一个1~n的环形排列.(正反都算) 其实就是找环了,对于一个链状序列,最小交换次数等于不在对应位置的数字个数减去环的个 ...

  6. 【习题 8-13 UVA - 10570】Meeting with Aliens

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 枚举1的位置在i 往右摆成一排. a[i+1]..a[n]..a[1]..a[i-1]变为有序的 ->寻找循环节,每个循环节的 ...

  7. UVA - 10570 Meeting with Aliens(外星人聚会)(暴力枚举)

    题意:输入1~n的一个排列(3<=n<=500),每次可以交换两个整数.用最少的交换次数把排列变成1~n的一个环状序列. 分析:正序反序皆可.枚举每一个起点,求最少交换次数,取最小值. 求 ...

  8. 【uva 10570】Meeting with Aliens(算法效率--暴力+贪心)

    题意:输入1~N的一个排列,每次可以交换2个整数,问使排列变成1~N的一个环状排列所需的虽少交换次数.(3≤N≤500) 解法:(又是一道我没打代码,光想和看就花了很久时间的题~QwQ)由于n很小,可 ...

  9. UVA题目分类

    题目 Volume 0. Getting Started 开始10055 - Hashmat the Brave Warrior 10071 - Back to High School Physics ...

随机推荐

  1. Ruby: Print WIN32OLE method names in Ruby

    class WIN32OLE   def list_ole_methods     method_names = ole_methods.collect {|m| m.name}     puts m ...

  2. 聊聊Spring的核心组件

    Spring的核心是IOC容器,它本质上是一个bean关系集合.而要实现它也是有beans,context,core三个模块完成的. beans包主要是负责bean的定义,创建和解析工作,里面用到了简 ...

  3. robotframework:appium切换webview后,在webview里滑动屏幕

    问题: 在用robot写手机淘宝app的自动化时,打开手机淘宝后,点击天猫国际,跳转到天猫国际页面,天猫国际页面是H5, 需要切换到对应的webview,切换到webview后,点击美妆菜单,跳转到美 ...

  4. codeforces 724C

    在一个nxm的镜面二维空间内,向(1,1)发射一条射线,来回反射,当遇到四个角之一时光线消失. 给K个点,问K个点第一次被射中是什么时候(v = sqrt(2)) 解:注意到只有 2*(n+m)个对角 ...

  5. wxPython学习笔记1

    wxpython介绍: wxPython 是 Python 语言的一套优秀的 GUI 图形库,允许 Python 程序员很方便的创建完整的.功能键全的  GUI 用户界面. wxPython 是作为优 ...

  6. Ubuntu16.04 开机显示The system is running in low-graphics mode

    1. 在"The system is running in low-graphics mode"界面,直接按 ctrl+alt+F1,会进入一个命令输入的模式 2. 输入用户名密码 ...

  7. UVaLive 6591 && Gym 100299L Bus (水题)

    题意:略. 析:不解释,水题. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024000000") #include < ...

  8. hdoj5402 【模拟/构造】

    题意: 给你一个矩阵,每个值都是非负,然后让你从左上角走到右下角,每个点只能走一次,求到终点的最大值,还要输出一条路径 思路: 一开始拿到还以为搜索之类的,但是发现神特么暴力+麻烦(因为路径这个东西. ...

  9. POJ3186【区间DP】

    题意: 每次只能取两端,然后第 i 次取要val[ i ]*i,求一个最大值 一切都是错觉[读者省略此段] 这道题目一开始想的就是记忆化搜索,然后太天真了?好像是,一开始用一维dp[ i ]直接代表一 ...

  10. python __builtins__ credits类 (15)

    15.'credits', 信用 class _Printer(builtins.object) | interactive prompt objects for printing the licen ...