CF #335 div1 A. Sorting Railway Cars

题目链接:http://codeforces.com/contest/605/problem/A

大意是对一个排列进行排序,每一次操作可以将一个数字从原来位置抽出放到开头或结尾,问最少需要操作多少次可以将原排列变为有序。

一个比较很想当然的算法是用长度减去最长上升子序列,但这是错误的。

反例:

5

1 3 4 5 2

按照n-lis,会得出答案1,但显然这是做不到的,答案应是2

 

正解应当是考虑最终变为有序时,所有未经操作的数字,应当是连续的。所以要使得操作次数最少就要求在原来数列中位置递增的最长连续数段。

以上面为例,则3 4 5这3个连续数字组成的数段满足在原来数列中位置递增,且是最长的数段。

代码如下:

 1 readInts=lambda: list(map(int, input().split()))
 2 n=int(input())
 3 a=readInts()
 4 p=[0]*n
 5 for i in range(n):
 6     p[a[i]-1]=i
 7 inc=1;ret=n-1
 8 for i in range(1,n):
 9     if p[i]>p[i-1]:
10         inc+=1
11     else:
12         inc=1
13     ret=min(ret,n-inc)
14 print(ret)

 

转载于:https://www.cnblogs.com/micrari/p/5393844.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值