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,如果变量还不用全局变量的话连内存 ...
随机推荐
- python核心编程中网络爬虫的例子
#!/usr/bin/env python import cStringIO # import formatter # from htmllib import HTMLParser # We use ...
- Android(java)学习笔记41:Map集合功能概述
1. 下面通过代码引入Map集合: 如下 package cn.itcast_01; import java.util.HashMap; import java.util.Map; /* * 作为学生 ...
- Android(java)学习笔记33:注册广播接收者
1. 下面我们先看一部分代码,由代码进行进一步的深入: registerReceiver( new BroadcastReceiver() {//onReceive中代码的执行时间不要超过5s,and ...
- Python语言程序设计基础(2)—— Python程序实例解析
温度转换 def tempConvert(ValueStr): if ValueStr[-1] in ['F','f']: ans = (eval(ValueStr[0:-1]) - 32)/1.8 ...
- 【[TJOI2007]可爱的质数】
题目 用一道板子题来复习一下\(bsgs\) \(bsgs\)用于求解形如 \[a^x\equiv b(mod\ p)\] 这样的高次不定方程 由于费马小定理的存在,我们可是直接暴力扫一遍\(p\), ...
- idea + maven + webapp 项目搭建
1.File-> New -> Project
- Visual Studio C++ Win32控制台应用程序,Win32项目,MFC的区别
背景 Visual Studio C++ 创建新项目蹦出来如下选项: Win32控制台应用程序,Win32项目,MFC有什么区别? 正文: Win32控制台,没有界面,命令行执行生成的文件则直接在后台 ...
- Linq 集合比较
List<RemindTbl> l_lstRemind = (from x in RemindTbl where (from y in RemindTblOld where x.Atten ...
- 使用补丁破解IntelliJ IDEA 2017收费版本(转)
1. 首先去官网http://www.jetbrains.com/idea/download/#section=windows下载Ultimate版(注意不是community版)下载并安装.一定要记 ...
- Struts2前期(这框架目前正处于淘汰状态)
Struts2第一天 Struts2的学习路线 1. Struts2的入门:主要是学习Struts2的开发流程(Struts2的开发流程.常见的配置.Action类的编写) 2. Struts2的Se ...