CodeForces 1082 E Increasing Frequency
2024-08-30 11:39:10
题意:给你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 ;
}
最新文章
- Android 四大组件之再论service
- mongodb morphia关联查询一例
- PHP的学习--可变变量
- Java集合系列:-----------07Map架构
- POJ 3264-Balanced Lineup, NYOJ 119-士兵杀敌3 线段树
- .NET设计模式(18):迭代器模式(Iterator Pattern)(转)
- Entity Framework Power Tools
- 微软职位内部推荐-ATG Engineer II
- Objective-c开发中混合使用ARC
- [ZETCODE]wxWidgets教程七:对话框
- POJ 2892 Tunnel Warfare (SBT + stack)
- java 使用Stack来判断Valid Parentheses
- lamda表达式和stream
- 如何为 SpringMVC 编写单元测试:普通 Controller 测试(转)
- MySQL 获得当前日期时间\时间戳 函数
- lodash用法系列(2),处理对象
- Python bytes decode() 方法
- 网易云社区有奖问答活动第二期——技术领导力、深入分布式、PHP圣经、Linux运维、Unity……三月热点图书等你拿!
- MySql C++调用库Connector/c++编译 和 接口封装【二】Connector/c++编译
- macdown在mac OS 中的配置
热门文章
- 【iOS】The filename 未命名.ipa in the package contains an invalid character(s)
- ";A valid provisioning profile for this executable was not found";问题
- kube-proxy源码解析
- javaweb基础整理随笔------jstl与el表达式
- Spring系列(一):Spring核心概念
- SpringBoot:Web开发
- 时间格式的字符串在ios中的转换问题
- python中下标和切片的使用
- JS闪电打字特效
- OCP培训 Oracle 12c/18c/19c OCP认证实战培训【送OCP优惠名额】