问题描述

LG5202


题解

\[opt[i]=xx+(cnt[i]-cnt[yy]<=0)
\]

发现\(cnt[i]-cnt[yy] <= 0\)只能有两种取值

于是直接堆优化即可


\(\mathrm{Code}\)

#include<bits/stdc++.h>
using namespace std; template <typename Tp>
void read(Tp &x){
x=0;char ch=1;int fh;
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-'){
fh=-1;ch=getchar();
}
else fh=1;
while(ch>='0'&&ch<='9'){
x=(x<<1)+(x<<3)+ch-'0';
ch=getchar();
}
x*=fh;
} const int maxn=300000+7; int n,k;
int opt[maxn],cnt[maxn];
char s[maxn]; struct node{
int val,pos;
bool operator <(node a)const{
return val==a.val?cnt[pos]>cnt[a.pos]:val>a.val;
}
}; priority_queue<node>q; int main(){
read(n);read(k);cin>>(s+1);
for(int i=1;i<=n;i++){
if(s[i]=='H'){
cnt[i]=cnt[i-1]+1;
}
else cnt[i]=cnt[i-1]-1;
}
q.push((node){0,0});
for(int i=1;i<=n;i++){
while(1){
int x=q.top().pos;
if(x>=i-k) break;
q.pop();
}
int xx=q.top().val,yy=q.top().pos;
opt[i]=xx+(cnt[i]-cnt[yy]<=0);
q.push((node){opt[i],i});
}
printf("%d\n",opt[n]);
return 0;
}

最新文章

  1. Activity 生命周期
  2. [LeetCode#252] Meeting Rooms
  3. python学习(一)
  4. Python 30分钟入门——数据类型 &amp;amp; 控制结构
  5. NM_CUSTOMDRAW 消息
  6. ES6箭头函数和它的作用域
  7. ruby 删除文件夹(包括文件夹中的文件夹和文件)
  8. angularjs表单
  9. 如何搭建自己的Maven远程私仓
  10. VK Cup 2017 - Квалификация 1
  11. 关于Vue修改默认的build文件存放的dist路径
  12. oracle_dataGuard_11G
  13. 为什么每次app访问服务器都建立新连接 导致服务器大量连接疯涨
  14. 前端 ---jQuery的补充
  15. Docker Swarm 配置文件存储
  16. 使用JdbcTemplate操作数据库(二十九)
  17. 【转】VxWorks中高精度实时时钟的实现及C语言汇编混合编程
  18. 关于 sql server 数据库权限乱七八糟的一些东西
  19. NFS介绍 NFS服务端安装配置 NFS配置选项
  20. python 编码规范起源:PEP8 编码规范中文版

热门文章

  1. VO(视图模型) 与 DTO(数据传输对象)的区别
  2. Laravel实现大型商城网站之用户注册短信发送项目实战功能开发
  3. tomcat修改使用指定的jdk版本
  4. Geodesic 什么是“测地线的”?
  5. Test111
  6. RMAN异机恢复主要步骤和注意事项
  7. 从简单Sql探索优化之道
  8. 关于tomcat对编码不正确的url参数报错的解决
  9. Samba安装及配置
  10. 基于node.js人脸识别之人脸对比