当前位置: 首页 > news >正文

2023NOIP A层联测9-天竺葵

天竺葵/无法阻挡的子序列/很有味道的题目

我们称一个长度为 k k k 的序列 c c c 是好的,当且仅当对任意正整数 i i i [ 1 , k − 1 ] [1,k-1] [1,k1] 中,满足 c i + 1 > b i × c i c_{i+1}>b_i \times c_i ci+1>bi×ci b b b 序列在下文描述。

小 L 现在给你两个序列 a , b a,b a,b,你需要从 a a a 序列中找出一个最长的子序列 c c c,使得 c c c 是好的。

输出这个最长的子序列的长度即可。


暂且把这个问题叫做带权最长上升子序列。

显然,类似于求 L I S LIS LIS,如果我们在 a a a 序列的前 i i i 个数中已经选了一个好的序列 c c c,那么 c c c 的最后一个一定是最小的(因为后面更容易满足条件增加长度)。

于是用二分, l o w i low_i lowi 表示长度为 i i i 的带权最长上升子序列的 a i ⋅ b i a_i\cdot b_i aibi 的最小值。

每次用 lower_bound \texttt{lower\_bound} lower_bound l o w low low 中查找大于等于 a i a_i ai 的第一个位置,用 a i ⋅ b i a_i\cdot b_i aibi 更新该位置,同时记录答案。

这样就做完了。

细节详见代码。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int n,ans=1;
ll a[1000001],b[1000001],low[1000001];
ll read()
{ll sum=0;int c=getchar();while(c<48||c>57) c=getchar();while(c>=48&&c<=57) sum=sum*10+c-48,c=getchar();return sum;
}
int main()
{freopen("C.in","r",stdin);freopen("C.out","w",stdout);n=read();for(int i=1;i<=n;i++) a[i]=read();for(int i=1;i<=n;i++) b[i]=read();memset(low,0x3f,sizeof(low));for(int i=1;i<=n;i++){int czn=lower_bound(low+1,low+1+ans,a[i])-low;ans=max(ans,czn);low[czn]=min(a[i]*b[czn],low[czn]);}cout<<ans;
}
http://www.lryc.cn/news/188951.html

相关文章:

  • react antd table表格点击一行选中数据的方法
  • 【VUEX】最好用的传参方式--Vuex的详解
  • 【.net core】yisha框架 SQL SERVER数据库 反向递归查询部门(子查父)
  • java处理时间-去除节假日以及双休日
  • 快讯|Tubi 有 Rabbit AI 啦
  • Zookeeper从入门到精通
  • 10.11作业
  • 如何对比github中不同commits的区别
  • 串的基本操作(数据结构)
  • ctfshow-web12(glob绕过)
  • hive3.1核心源码思路
  • LATR:3D Lane Detection from Monocular Images with Transformer
  • 什么是UI自动化测试工具?
  • 计算顺序表中值在100到500之间的元素个数
  • 【问题总结】级数的括号可以拆吗?
  • 抖音自动养号脚本+抖音直播控场脚本
  • uvm中transaction的response和id的解读
  • 第四节(1):EXCEL中判断一个WORD文件是否被打开
  • java.util.concurrent.locks.Condition详解
  • 选择适合变更管理的产品开发工具的要点和建议
  • 小程序 词云图 echarts-for-weixin-wordcloud
  • VScode配置Jupyter
  • java模拟GPT流式问答
  • 【好玩】如何在github主页放一条贪吃蛇
  • 顶顶通ASR安装配置说明
  • VMware和别的服务器 ,组建局域网那些事 。
  • 自监督DINO论文笔记
  • 计算机视觉: 基于隐式BRDF自编码器的文生三维技术
  • 分类预测 | MATLAB实现KOA-CNN-BiLSTM开普勒算法优化卷积双向长短期记忆神经网络数据分类预测
  • Java队列相关面试题