有N个木棍,长度和宽度已知。现在要一个接一个的拼接木棍。当然我们需要计算总共拼接的时间。有以下规则: 对于第一根处理的木棍,我们需要1分钟。 之后处理的木棍,如果说他的长度l和宽度w满足l0<=l并且w0<=w,那么我们不需要额外再花费时间去拼接。 比如,对于(9,4),(2,5),(1,2),(5,3),(4,1)这5根木棍,我们需要花费最少2分钟的时间:(4,1),(5,3),(9,4)和(1,2),(2,5)。 https://www.luogu.com.cn/blog/xiaosongliu/python3-zhi-mu-hun-jia-gong
python 的bisect实现二分查找。 此题是很简单的最长非递减序列的动态规划。 先按照“宽”主关键字,“长”次关键字倒序排序。然后再从次关键字——“长”寻找最长递增序列。序列长度就是答案。(单调非递增的列数就等于单调递增长度——也可以写贪心实现)
import bisect
N = int(input())
s = []
t = input().split()
for i in range(N):
s.append([int(t[i * 2]), int(t[i * 2 + 1])])
s.sort(key=lambda x: (x[0], x[1]), reverse=True)#排序
ans = [s[0][1]]
len = 1
for i in range(1, N):
if s[i][1] > ans[len - 1]:
ans.append(s[i][1])
len += 1
else:
k = bisect.bisect_left(ans, s[i][1])#二分
ans[k] = s[i][1]
print(len)