Fire

分析:

首先,明确题意:b1,b2,……,bn 交换为b2,……,bn,b1,但这并不是意味着只能从b1开始交换,(这点从样例中可以看出),并且也不意味着交换的必须是连续的一串,可以是几个单点,如: 原序列:1 2 3 4 5,交换(1 3 5)后

新序列:3 2 5 4 1

交换时必须按照环的方式顺时针或逆时针转动,这并没有限制,只需要一个位置移动到另一个位置时将他顶替掉,他去找他自己应该到的位置就好了,最终是按一个环的移动方式移动,但不一定是从左到右或从右到左,方向交叉。

所以:

我们首先得到目标序列1  2  5  4  3

然后与原序列比较    1  2  3  4  5

做差:              0  0  2  0  -2

1,2,4的差值一样,另外,因为原序列的有序性,无论如何转动目标序列或原序列,1,2,4的差值也一定相同,所以,差值相同的数目一定不变。那么差值相同意味着什么呢,由例子可以看出,差值为零,则该序列与原序列状态相同,所以,我们把差值相同个数最多的移动为零,则剩下的进行交换,所花费的代价一定最小(整体移动一个序列不花费代价,因为整体移动时符合题意,并且没有交换) 。

做法:

按照题意得到目标序列,若得不到原序列则输出 -1;

得到目标序列以后与原序列比较,做差,找到差值相同数目最多的个数S,然后用总数减去S,即为所要花费的最小代价。另外,有与序列方向不确定,所以我们要将原序列倒过来,再按照此做法做一遍。两次取最小值便是答案。

代码实现:

program exam;

var

i,j,kl,kr,m,n,sum,max,min,ans:longint;

a:array[1..50000] of longint;

b:array[0..50000] of longint;

t:array[0..50000] of longint;

l,r:array[1..50000] of longint;

begin

assign(input,'1.txt');

reset(input);

readln(n);

for i:=1 to n do

readln(l[i],r[i]);

a[1]:=1;

a[2]:=r[1];

sum:=2;

for i:=1 to n do

begin

kl:=l[a[sum]];

kr:=r[a[sum]];

if a[sum-1]=kl then

begin

inc(sum);

a[sum]:=kr;

end;

if a[sum-1]=kr then

begin

inc(sum);

a[sum]:=kl;

end;

if (a[sum]<>kl) and (a[sum]<>kr) then

begin

writeln('-1');

halt;

end;

if sum=n then

break;

end;

for i:=1 to n do

begin

b[i]:=a[i]-i;

if b[i]<0 then

b[i]:=b[i]+n;

end;

max:=0;

for i:=1 to n do

begin

inc(t[b[i]]);

if t[b[i]]>max then

max:=t[b[i]];

end;

ans:=n-max;

fillchar(b,sizeof(b),0);

fillchar(t,sizeof(t),0);

max:=0;

for i:=1 to n do

begin

b[i]:=a[i]-(n-i+1);

if b[i]<0 then

b[i]:=b[i]+n;

end;

for i:=1 to n do

begin

inc(t[b[i]]);

if t[b[i]]>max then

max:=t[b[i]];

end;

min:=n-max;

if min<ans then

ans:=min;

writeln(ans);

close(input);

end.

span><�6 0]X�NMsoNormal>begin

ans:=maxlongint;

readln(n);

for i:=1 to n do

readln(a[i]);

tmp:=a;

qsort(1,n);

c:=a;

a:=tmp;

dp;

writeln(ans);

end.

Fire的更多相关文章

  1. 关于SequeezeNet中的Fire Module

    在论文<SQUEEZENET: ALEXNET-LEVEL ACCURACY WITH 50X FEWER PARAMETERS AND <0.5MB MODEL SIZE>中,作者 ...

  2. FZU 2150 Fire Game

    Fire Game Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit St ...

  3. Android 轻量级输入校验库:Fire Eye

    Fire Eye是一款轻量级简单易用的Android校验库. FireEye 2.0 在 1.0 的基础上,全部重写了代码,并优化了架构,性能上和逻辑上都大大提升.只需要几行代码,即可验证用户输入,并 ...

  4. ACM: FZU 2150 Fire Game - DFS+BFS+枝剪 或者 纯BFS+枝剪

    FZU 2150 Fire Game Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u ...

  5. UVA 11624 Fire!(广度优先搜索)

    题目大意:在一个N*M的迷宫内,J代表某人(只有一个),F代表火(可能不只一个),#代表墙,火每分钟会向四周除了墙以外的地方扩散一层,问人能否在没被火烧到 之前逃出迷宫,若能逃出输出最短时间.很明显的 ...

  6. Amazon的Fire Phone之于Android开发者

    在上周Amazon也耐不住加入了手机竞争行列之中,发布了自己的Fire Phone,于是Android家族又多了一位变种成员,Android系统的碎片化程度也进一步加剧.因为工作的关系,我有幸在上个月 ...

  7. Fire!(BFS)

    Fire! Time Limit:1000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit Status Descr ...

  8. FZU Problem 2150 Fire Game

    Problem 2150 Fire Game Accept: 145    Submit: 542 Time Limit: 1000 mSec    Memory Limit : 32768 KB P ...

  9. hdu 1045:Fire Net(DFS经典题)

    Fire Net Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

随机推荐

  1. 【Java布局】FlowLayout布局时设定组件大小

    默认的JPanel中,采用的是FlowLayout布局 下面是api中的定义: JPanel(boolean isDoubleBuffered)           创建具有 FlowLayout 和 ...

  2. 广播后刷新界面-调用其他界面的方法触动广播后刷新该界面UI

    new CigaretteLoginActivity().login(ac,"switch_account",list.get(arg2).CUST_CODE,list.get(a ...

  3. Spring scope

    scope用来声明IOC容器中的对象应该处的限定场景或者说该对象的存活空间,即在IOC容器在 对象进入相应的scope之前,生成并装配这些对象,在该对象不再处于这些scope的限定之后,容器通常会销毁 ...

  4. 转 夕甲甲:孔乙己之 C++ 版

    欧欧匹代码的格局,是和别的编程模式不同的:首先要有一个构造函数:基类里只定义了函数的形式,可以随时通过派生增加不同的实现.那些程序员们,每每学会了继承和多态,便可以接一个项目,——这是十年前的事,现在 ...

  5. 【C#】项目优化实战

    [C#]项目优化实战 一. 数据库设计 1. 常量的枚举值直接存中文不要存数字(注意是常量,如果显示值可变就不能) 例如:男女,在数据库中不要存1和0,直接存男和女. 这样的好处:读取数据的时候可以避 ...

  6. SpringRMI远程方法调用

    Spring为各种远程访问技术的集成提供了工具类. 该小段引用自 http://www.open-open.com/lib/view/open1408957290478.html Spring远程支持 ...

  7. Windows上Python2和3如何兼容

    作者:匿名用户链接:https://www.zhihu.com/question/21653286/answer/95532074来源:知乎著作权归作者所有,转载请联系作者获得授权.想学习Python ...

  8. cinder节点部署

    其实看基础理论篇大家也可以看出来,cinder跟nova流程比较像,是这样的,nova为云主机提供了虚拟资源,cinder则是提供存储相关的资源,cinder的小伙伴叫swift,不过这个一般没人用了 ...

  9. windows下安装composer抛出Composer\Downloader\TransportException异常解决办法

    1. 把默认的 secure-http 改成false composer config -g secure-http false 2. 修改配置文件 #修改全局文件(推荐) composer conf ...

  10. hdu 1258 Sum It Up(dfs+去重)

    题目大意: 给你一个总和(total)和一列(list)整数,共n个整数,要求用这些整数相加,使相加的结果等于total,找出所有不相同的拼凑方法. 例如,total = 4,n = 6,list = ...