题目传送门

题意:给你n个数和一个c, 现在有一个操作可以使得 [ l, r ]区间里的所有数都加上某一个值, 现在问你c最多可以是多少。

题解:

pre[i] 代表的是 [1,i] 中 c 的个数是多少。

suf[i] 代表的是 [i,n] 中 c 的个数是多少。

我们可以处理出这些信息。

然后我们从后往前处理信息。

现在给定一个b[x], b[x] 记录的是 [l, r] 中 x 的个数 + [r+1, n] 中 c的个数。

那么 每次出现一个新的 x, 现在可以转移到b[x]的状态是 max(b[x], suf[i+1]) + 1。

然后我们对答案求最大就好了。

#include<bits/stdc++.h>
using namespace std;
#define Fopen freopen("_in.txt","r",stdin); freopen("_out.txt","w",stdout);
#define LL long long
#define ULL unsigned LL
#define fi first
#define se second
#define pb push_back
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define lch(x) tr[x].son[0]
#define rch(x) tr[x].son[1]
#define max3(a,b,c) max(a,max(b,c))
#define min3(a,b,c) min(a,min(b,c))
typedef pair<int,int> pll;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const LL mod = (int)1e9+;
const int N = 5e5 + ;
int a[N];
int b[N];
int suf[N];
int pre[N];
int main(){
int n, c;
scanf("%d%d", &n, &c);
for(int i = ; i <= n; ++i)
scanf("%d", &a[i]);
int ans = ;
for(int i = ; i <= n; ++i) pre[i] = pre[i-] + (a[i] == c);
for(int i = n; i >= ; --i){
b[a[i]] = max(b[a[i]], suf[i+]) + ;
suf[i] = suf[i+] + (c == a[i]);
ans = max(ans, pre[i-]+b[a[i]]);
}
cout << ans << endl;
return ;
}

最新文章

  1. Android 四大组件之再论service
  2. mongodb morphia关联查询一例
  3. PHP的学习--可变变量
  4. Java集合系列:-----------07Map架构
  5. POJ 3264-Balanced Lineup, NYOJ 119-士兵杀敌3 线段树
  6. .NET设计模式(18):迭代器模式(Iterator Pattern)(转)
  7. Entity Framework Power Tools
  8. 微软职位内部推荐-ATG Engineer II
  9. Objective-c开发中混合使用ARC
  10. [ZETCODE]wxWidgets教程七:对话框
  11. POJ 2892 Tunnel Warfare (SBT + stack)
  12. java 使用Stack来判断Valid Parentheses
  13. lamda表达式和stream
  14. 如何为 SpringMVC 编写单元测试:普通 Controller 测试(转)
  15. MySQL 获得当前日期时间\时间戳 函数
  16. lodash用法系列(2),处理对象
  17. Python bytes decode() 方法
  18. 网易云社区有奖问答活动第二期——技术领导力、深入分布式、PHP圣经、Linux运维、Unity……三月热点图书等你拿!
  19. MySql C++调用库Connector/c++编译 和 接口封装【二】Connector/c++编译
  20. macdown在mac OS 中的配置

热门文章

  1. 【iOS】The filename 未命名.ipa in the package contains an invalid character(s)
  2. &quot;A valid provisioning profile for this executable was not found&quot;问题
  3. kube-proxy源码解析
  4. javaweb基础整理随笔------jstl与el表达式
  5. Spring系列(一):Spring核心概念
  6. SpringBoot:Web开发
  7. 时间格式的字符串在ios中的转换问题
  8. python中下标和切片的使用
  9. JS闪电打字特效
  10. OCP培训 Oracle 12c/18c/19c OCP认证实战培训【送OCP优惠名额】