蓝桥骑士lanqi ao0J题号1188

题目描述

小明是蓝桥王国的骑士,他喜欢不断突破自我。这天蓝桥国王给他安排了 N 个对手,他们的战力值分别为 a1​,a2​,...,an​,且按顺序阻挡在小明的前方。对于这些对手小明可以选择挑战,也可以选择避战。身为高傲的骑士,小明从不走回头路,且只愿意挑战战力值越来越高的对手。请你算算小明最多会挑战多少名对手。

输入描述

输入第一行包含一个整数 N,表示对手的个数。

第二行包含 N 个整数 a1​,a2​,...,an​,分别表示对手的战力值。

​。

输出描述

输出一行整数表示答案。

输入输出样例

输入

6
1 4 2 2 5 6

输出

4

思路

最长递增子序列(LIS)问题给定一个长度为n的数组,找出一个最长的单调递增子序列。

例:序列A={5,6,7,4,2,8,3},它最长的单调递增子序列为{5,6,7,8},长度为4。

做法:

新建一个 low 数组,low [ i ]表示长度为i的LIS结尾元素的最小值。对于一个上升子序列,显然其结尾元素越小,越有利于在后面接其他的元素,也就越可能变得更长。因此,我们只需要维护 low 数组,对于每一个a[ i ],如果a[ i ] > low [当前最长的LIS长度],就把 a [ i ]接到当前最长的LIS后面

那么,怎么维护 low 数组呢? 对于每一个a [ i ],如果a [ i ]能接到 LIS 后面,就接上去;否则(a[ i ] 小于 low [当前最长的LIS长度]),就用 a [ i ] 取更新 low 数组。具体方法是,在low数组中找到第一个大于等于a [ i ]的元素low [ j ],用a [ i ]去更新 low [ j ]。如果从头到尾扫一遍 low 数组的话,时间复杂度仍是O(n^2)。我们注意到 low 数组内部一定是单调不降的,所有我们可以二分法来查询 low 数组,找出第一个大于等于a[ i ]的元素。二分一次 low 数组的时间复杂度的O(logn),所以总的时间复杂度是O(nlogn)。

  我们再举一个例子:有以下序列A[ ] = 3 1 2 6 4 5 10 3,5,求LIS长度。

  我们定义一个B[ i ]来储存可能的排序序列len 为LIS长度。我们依次把A[ i ]有序地放进B[ i ]里。 (为了方便,i的范围就从1~n表示第i个数)

A[1] = 3,把3放进B[1],此时B[1] = 3,此时len = 1,最小末尾是3

  A[2] = 1,因为1比3小,所以可以把B[1]中的3替换为1,此时B[1] = 1,此时len = 1,最小末尾是1

  A[3] = 2,2大于1,就把2放进B[2] = 2,此时B[ ]={1,2},len = 2

  同理,A[4]=6,把6放进B[3] = 6,B[ ]={1,2,6},len = 3

  A[5]=4,4在2和6之间,比6小,可以把B[3]替换为4,B[ ] = {1,2,4},len = 3

  A[6] = 5,B[4] = 5,B[ ] = {1,2,4,5},len = 4

  A[7] = 10,B[5] = 10,B[ ] = {1,2,4,5,10},len = 5

  A[8] = 3,3在2和4之间,比10小,可以把B[3]替换为3,B[ ] = {1,2,3,5,10},len = 5

A[9] = 5,5在B[4],把B[4]替换为5(这里其实没有替换,因为把原来的5替换成A[9]的5),B[ ] = {1,2,3,5,10},len = 5

代码

import bisect
n=int(input())
a=[int(i) for i in input().split()]
b=[a[0]]  # 初始化,用来存最长递增子序列
for i in range(1,n):index=bisect.bisect_left(b,a[i])  # index:大于等于a[i]的第一个数的下标if index==len(b):       # 返回下标等于b数组长度,说明大于b中最后一个数b.append(a[i])        # 将a[i]添加到b最后else:                   # a[i]小于最后一个数,则将更新index对应的元素b[index]=a[i]
print(len(b))

注:index = bisect.bisect_left(b,a[i]) 返回大于等于a[i]的第一个数的下标

举个栗子:A = [1,3,5,7,9],现在要找5,则index = bisect.bisect_left(A,5),返回index = 2;现在要找6,则返回index = 3

Tipsindex = bisect.bisect_left(b,a[i]) :要找的数在a数组里,则返回a[i]下标,否则返回大于a[i]的第一个数的下标

总结

最长递增子序列(LIS)问题,对于每一个a[ i ],有两种情况:

①  a[ i ] > 当前low [ ]最后一个数,就把 a [ i ]接到当前最长的LIS后面。

②  a[ i ] 小于等于当前low [ ]最后一个数,找到第一个大于等于a [ i ]的元素low [ j ](用二分查找)并用a[i]替换low[j].

蓝桥杯刷题026——蓝桥骑士(二分法)相关推荐

  1. ACMoi蓝桥杯刷题网站推荐

    ACM oi 蓝桥杯 刷题网站推荐 ACM刷题oj oi刷题 蓝桥杯刷题oj 刷题网站推荐 刷题的oj越来越多 肯定都有他们自己的特点 今天给各位朋友推荐一下一些网站 新手(中文题) 1.洛谷容易的题 ...

  2. 【蓝桥杯刷题冲刺辅导】掌握递归·DFS解题套路,这一文足以?

    大家好,我是安然无虞. 目录 一.刷题前和铁汁们唠一唠 1.刷题前须知 2.刷题时套路 <1>套路 <2>背下列常用数 ​ <3>投机取巧:根据数据范围确定算法 ​ ...

  3. 蓝桥杯刷题日记 更新到2022/2/5

    蓝桥杯刷题日记 文章目录 蓝桥杯刷题日记 DAY1 1.递归实现指数型枚举 2.递归实现组合型枚举 3.递归实现排列型枚举 Day2 1.八皇后问题 *2.费解的开关 3.带分数 Day3 1.飞行员 ...

  4. 蓝桥杯刷题之分享或许会迟到,但绝不会缺席

    不好意思大家.今晚因为需要学习java 所以博客写的有点晚了,但我中午就把这三道题准备好了!!! 第三天的蓝桥杯刷题 回文串 挖掘机技术哪家强 说反话 回文串 大家看这个题目.或许会想到回文数之前,但 ...

  5. 小白要努力之为了蓝桥杯刷题!!!超简单哦!!!

    分享一个歌词直接让我笑喷的歌词----之前我不听歌的,毕竟第一次听到.学习的目的就是找工作,或者创业,但就是一个字"挣钱" 下面直接开始正题吧 首先科普一些知识,全局变量定义的时候 ...

  6. 蓝桥杯刷题015——最少刷题数(二分法+前缀和)

    问题描述 小蓝老师教的编程课有 N 名学生, 编号依次是 1-N .第 i 号学生这学期刷题的数量是 Ai​ . 对于每一名学生, 请你计算他至少还要再刷多少道题, 才能使得全班刷题比他多的学生数不超 ...

  7. 蓝桥杯刷题以及算法解析的网址

    蓝桥杯题目算法解析参考博客:https://blog.csdn.net/qq_38648587 做题目的网站,有实时模拟比赛:https://oj.ahstu.cc/JudgeOnline/probl ...

  8. 蓝桥杯刷题007——七段码

    七段码 七段码2020年第十一届蓝桥杯省赛,填空题,lanqiao0J题号595 [问题描述] 七段数码管,一共有7个发光二极管,问能表示多少种不同的字符,要求发光的二极管是相连的. 七段数码管,一共 ...

  9. 蓝桥杯刷题冲刺 | 倒计时14天

    作者:指针不指南吗 专栏:蓝桥杯倒计时冲刺

最新文章

  1. libevent库的安装与使用
  2. 【Android 返回堆栈管理】打印 Android 中当前运行的 Activity 任务栈信息 | Activity 任务栈信息分析 | Activity 在相同 Stack 中的不同 Task
  3. java的多线程实现方式_java 多线程实现方式
  4. git pull 失败 ,提示:fatal: refusing to merge unrelated histories
  5. C语言求本金,求本金,试过了,调试了还是不行
  6. 数据库-MySQL-JDBC-execute、executeUpdate、executeQuery
  7. 【JQuery】jQuery中的常用方法小结
  8. silverlight:分享一个不错的自定义布局CollectionFlow(可用于制作相册的哦!)
  9. 拓端tecdat|新零售消费者特征的数据视野
  10. C++类的静态成员函数
  11. 种子点生长算法下——三维种子点生长
  12. 微信小程序UI设计(一)之开发前言
  13. xp无法查看工作组计算机 服务没有启动,XP系统弹出“无法查看工作组计算机”提示怎么办?...
  14. python立即关机,Python实现自动关机
  15. 搭建个人博客【搭建Hexo+Fluid博客并部署到GitHub/云服务器(阿里云/腾讯云)】
  16. wpf Route Event Code Snippet
  17. verilog奇数分频,三分频实例
  18. 【20210416期AI简报】微软分层ViT模型开源、 DIY一只“眼睛”摄像头
  19. java支持库 易语言_易语言支持库简单安装加载添加
  20. 2020第十一届蓝桥杯国赛Python组

热门文章

  1. 【Kaggle笔记】预测Imdb电影评分(随机森林)
  2. 金蝶云星空简单账表列汇总
  3. 罗技G500 WIN7 WIN8 64位系统 SETPOINT 识别问题
  4. (附源码)计算机毕业设计SSM大学生创新创业项目活动管理平台
  5. 【实战系列】B360主板+Intel 8代i5 8400 CPU+核显完美重装WIN7系统
  6. vue中使用HKPlayer播放器连接摄像头监控
  7. MySql基础——表数据操作
  8. 日志组件Log2Net的介绍和使用(附源码开源地址)
  9. 自媒体短视频账号运营、涨粉全攻略分享
  10. 联想计算机主机哪个是独立显卡,联想显卡怎么切换_联想双显卡怎么切换-系统城...