首先,我们不难发现N个位置都选一定不会比少选任意几个差,所以我们就先设定我们将这N个修改机会都用上, 那么如果点 i">ii 前有sumv">sumvsumv个可修改点要被选的话,当前点被选择的条件是减掉sumv">sumvsumv后依然能和前面已减掉过sumv">sumvsumv的进行匹配。

Code:

#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 100000 + 4;
int p, maxv[maxn], tags[maxn], nums[maxn], val[maxn];
inline int lowbit(int t)
{
return t & (-t);
}
inline void update(int x,int delta)
{
while(x <= p + 2)
maxv[x] = max(maxv[x], delta), x += lowbit(x);
}
inline int query(int x)
{
int ans = 0;
while(x > 0) ans = max(ans, maxv[x]) , x -= lowbit(x);
return ans;
}
int main()
{
freopen("calligraphy9.in","r",stdin);
//freopen("calligraphy.","w",stdout);
int n, cnt = 0, sumv = 0, ans = 0, fin = 0;
scanf("%d",&n);
for(int i = 1;i <= n; ++i)
{
char g[10];
scanf("%s",g);
if(g[0] == 'N')
{
tags[i] = 1;
++sumv;
continue;
}
scanf("%d",&val[i]);
}
ans = sumv;
for(int i = n;i >= 1;--i)
{
if(tags[i]) --sumv;
else val[i] -= sumv;
}
for(int i = 1;i <= n; ++i)if(!tags[i]) nums[++cnt] = val[i];
sort(nums + 1, nums + 1 + cnt);
for(int i = 1;i <= n; ++i)
if(!tags[i])
{
val[i] = lower_bound(nums + 1, nums + 1 + cnt, val[i]) - nums;
p = max(p, val[i]);
}
for(int i = 1;i <= n; ++i)
{
if(tags[i]) continue;
int u = val[i];
int pre = query(u - 1);
fin = max(fin, pre + 1);
update(u, pre + 1);
}
printf("%d",ans + fin);
fclose(stdin);
return 0;
}

最新文章

  1. 3.C#面向对象基础聊天机器人
  2. 创建用资源管理器打开FTP位置
  3. 【Bugly干货】Android性能优化典范之多线程篇
  4. 十分钟搞定CSS选择器
  5. c中的基本运算
  6. .NET Core)的ZooKeeper异步客户端
  7. oracle 表查询二
  8. Android中弹出输入法界面不影响app界面布局
  9. SQL2008和SQL2000可以跨服务器连接查询的测试实例
  10. Java compile时,提示 DeadCode的原因
  11. Java单例模式的线程安全问题
  12. Linux学习历程——Centos 7 账户管理命令(用户篇)useradd usermod userdel
  13. re模块正则表达式
  14. java 打包 war包
  15. 复制神器Ditto使用方法详细说明
  16. Linux&#160;sudo&#160;命令使用简介
  17. Python os.md
  18. main函数的参数argc和argv
  19. Dlib与OpenCV图片转换
  20. java第二次实验报告20135231

热门文章

  1. Codeforces 892C/D
  2. QT5的模块介绍【摘】
  3. 【例题 4-4 uva 213】Message Decoding
  4. 【Codeforces 342A】Xenia and Divisors
  5. 手动编译java的package问题,及演示继承的基本实现
  6. 支付宝钱包手势password破解实战(root过的手机可直接绕过手势password)
  7. Ralink5350开发环境搭建
  8. 安装eclipse maven插件m2eclipse No repository found containing
  9. POJ1179 Polygon 区间DP
  10. Ubuntu Tomcat Service