HDU暑假多校第八场J-Taotao Picks Apples
一、题意
给定一个序列,之后给出若干个修改,修改的内容为在原序列的基础上,将某一位元素的值改成给定的值<每次修改相互独立,不保存修改后的结果>。之后询问,在选择第一位元素的情况下,最长递增子序列的长度是多少。
二、题解
考虑不经修改的情况,应当设dp[i]为选取当前位情况下的最长递增子串的长度。则对于这道题,应当认为对于修改a为b,设l_pos为a左边最大的元素的位置,r_pos为a右边大于max(b,r_pos)的元素的位置。则有ans = dp[1] - dp[l_pos] + 1 + dp[r_pos];对于b本身大于位于l_pos的元素,应当给结果+1。
#include<bits/stdc++.h>
using namespace std; #define ll long long const int MAXN = ; class Node{
public:
int l,r,lc,rc,maxx;
};
Node nodes[MAXN];
int nodes_num;
int t,n,m; int arr[MAXN];
int dp[MAXN]; void tree_init(int a,int b){
int now = nodes_num++;
nodes[now].l = a;
nodes[now].r = b;
if(a == b-){
nodes[now].maxx = arr[a];
return ;
}
int mid = (a+b)/;
nodes[now].lc = nodes_num;
tree_init(a,mid);
nodes[now].rc = nodes_num;
tree_init(mid,b);
nodes[now].maxx = max(nodes[nodes[now].lc].maxx,nodes[nodes[now].rc].maxx);
} int find_max(int now){
int l = nodes[now].l;
int r = nodes[now].r;
if(l == r-)return l;
int maxx = nodes[now].maxx;
int lc = nodes[now].lc;
int rc = nodes[now].rc;
if(maxx == nodes[lc].maxx)return find_max(lc);
else return find_max(rc);
} int find_biggest(int now,int a,int b){
int l = nodes[now].l;
int r =nodes[now].r;
if(l == a&&r == b){
return find_max(now);
}
int mid = (l+r)/;
int ret ;
int lc = nodes[now].lc;
int rc = nodes[now].rc;
if(a<mid){
ret = find_biggest(lc,a,min(b,mid));
if(b>mid){
int tmp = find_biggest(rc,mid,b);
ret = arr[ret] >= arr[tmp] ? ret:tmp;
}
}else ret = find_biggest(rc,a,b);
return ret;
} int find_left(int now,int key){
int l = nodes[now].l;
int r = nodes[now].r;
if(l == r-)return l;
int lc = nodes[now].lc;
int rc = nodes[now].rc;
if(nodes[lc].maxx > key)return find_left(lc,key);
else return find_left(rc,key);
} int find_first(int now,int pos, int key){
int l = nodes[now].l;
int r = nodes[now].r;
if(l >= pos){
return find_left(now,key);
}
int mid = (l+r)/; int lc = nodes[now].lc;
int rc = nodes[now].rc;
int ret ;
if(pos < mid && nodes[lc].maxx > key){
ret = find_first(lc,pos,key);
if(ret >= pos && arr[ret] > key)return ret;
}
if(nodes[rc].maxx <= key)return r-;
return find_first(rc,pos,key); } void init(){
scanf("%d %d",&n,&m);
nodes_num = ;
arr[] = -;
arr[n+] = INT_MAX;
for(int i=;i<=n;++i)scanf("%d",&arr[i]);
tree_init(,n+);
memset(dp,,sizeof(dp));
for(int i=n;i>=;--i){
dp[i] = dp[find_first(,i+,arr[i])]+;
}
dp[] = dp[]+;
for(int i=;i<m;++i){
int a,b;
scanf("%d %d",&a,&b);
int l_pos = find_biggest(,,a);
int key = max(b,arr[l_pos]);
int r_pos = find_first(,a+,max(b,arr[l_pos]));
int ans = dp[] - dp[l_pos] + + dp[r_pos];
if(b > arr[l_pos] )ans++;
cout<<ans<<'\n';
} } int main(){ cin>>t;
while(t--)init(); return ;
}
HDU暑假多校第八场J-Taotao Picks Apples的更多相关文章
- HDU暑假多校第八场G-Card Game
一.题意 给出N个卡牌,卡牌的正反两面具有两个数字,取值范围为[1,2*n],给出若干个默认正面向上的卡牌,求最小反转多少张卡牌可以使得,每张卡牌朝上的面上都有一个不同的数字,同时满足最小反转次数的反 ...
- HDU暑假多校第四场J-Let Sudoku Rotate
一.题意 Sudoku is a logic-based, combinatorial number-placement puzzle, which is popular around the wor ...
- HDU暑假多校第六场K-werewolf
一.题意 好人必然说真话,坏人不一定说真话,给定N个人的言论<每人一个发言.不谈及自己>,要求指出有多少个人一定是好人,有多少个人一定是坏人.#define 狼人 坏人#define 村民 ...
- HDU暑假多校第三场H.Monster Hunter
一.题意 给定一个树状地图,每个树节点上有一只怪物,打死一只怪物的过程中将会消耗A点HP,打死之后将会获得B点HP.因为树状结构,所以每只怪物必须先打死父节点的怪兽之后在打死子节点的怪物.现在,给定每 ...
- 2019牛客多校第八场 F题 Flowers 计算几何+线段树
2019牛客多校第八场 F题 Flowers 先枚举出三角形内部的点D. 下面所说的旋转没有指明逆时针还是顺时针则是指逆时针旋转. 固定内部点的答案的获取 anti(A)anti(A)anti(A)或 ...
- 牛客多校第3场 J 思维+树状数组+二分
牛客多校第3场 J 思维+树状数组+二分 传送门:https://ac.nowcoder.com/acm/contest/883/J 题意: 给你q个询问,和一个队列容量f 询问有两种操作: 0.访问 ...
- 2020牛客多校第八场K题
__int128(例题:2020牛客多校第八场K题) 题意: 有n道菜,第i道菜的利润为\(a_i\),且有\(b_i\)盘.你要按照下列要求给顾客上菜. 1.每位顾客至少有一道菜 2.给顾客上菜时, ...
- 2014 HDU多校弟六场J题 【模拟斗地主】
这是一道5Y的题目 有坑的地方我已在代码中注释好了 QAQ Ps:模拟题还是练的太少了,速度不够快诶 //#pragma comment(linker, "/STACK:16777216&q ...
- 2014 HDU多校弟五场J题 【矩阵乘积】
题意很简单,就是两个大矩阵相乘,然后求乘积. 用 Strassen算法 的话,当N的规模达到100左右就会StackOverFlow了 况且输入的数据范围可达到800,如果变量还不用全局变量的话连内存 ...
随机推荐
- 源码安装mysql,及主从同步
源码安装mysql [可选] 如果用源码安装cmake软件: cd /home/oldboy/tools/ tar xf cmake-.tar.gz cd cmake- ./configure #CM ...
- 怎样下载YouTube播放列表视频
YouTube上面的视频种类丰富多彩,要是你想利用上面的资源来学习的话,足够你钻研很长时间了.如果你想在YouTube上面学习一门教程,比如Python,通常这些内容一个视频肯定装不下,会分为好多个视 ...
- OC 构造方法
#import <Foundation/Foundation.h> @interface Student : NSObject { int _age; int _no; } - (void ...
- 解决svn中“工作副本已经锁定”,或者svn清理失败的解决方法
刚开始遇到这个问题还以为是没有插网线的原因,客户端和服务器都在我的电脑上,但是更新和提交都执行不了,以为是没有插网线就没把这个小问题放在心上,今早上还是这样,就不得不解决一下了. 更新或者提交前要执行 ...
- linux自动备份文件 并上传到远程服务器 脚本实现
(1)在服务器上创建备份目录,并赋予权限 mkdir -p /backup/bakdata #新建数据备份目录(2)完成备份脚本操作新建脚本文件 vi bakdata.sh添加 ...
- Uva 10559 消除方块
题意: 每次可以选择一个区间(连续相同的序列)消除,得分为 len*len:问最大得分. 分析: 很容易想到是区间DP,但是不像普通的区间DP一样切割方式~~~ 如果定义 d[ i ][ j ] 区间 ...
- 2018.11.28 OGNL表达式与struts2框架结合的体现---在配置文件中体现(补充)
Demo3Action配置 struts.xml 主配置文件配置 地址栏输入 http://localhost:8080/StrutsDay03/Demo3Action 对于主配置的文件参数而言,如果 ...
- XCode项目配置可访问 非 https 接口的方法
打开项目的info.plist文件,右键- open as sourceCode .在代码中添加: <key>NSAppTransportSecurity</key> < ...
- bitmap和drawable的相互转化以及setImageResource(),setImageDrawable(),setImageBitmap()
从本地获取drawable图片:getResources().getDrawable(R.drawable.**) 获取bitmap:Bitmap b=BitmapFactory().decodeRe ...
- java实现简单计算器功能
童鞋们,是不是有使用计算器的时候,还要进入运行,输入calc,太麻烦了,有时候甚至还忘记单词怎么拼写,呵呵程序员自己写代码实现,又简单,又方便啊 以下为代码(想要生成可执行工具可参考:http://w ...