LeetCode刷题记录day6:木棍拼接(招行信用卡2020)

有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)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值