题目链接

problem

给出一个长度为\(n(n\le 10^5)\)的只包含01的字符串。把尽可能多的1变为0,使得对于所有的\(l \in [1,n],r\in [l,n]\),区间\([l,r]\)的最长不下降子序列的长度不变。

solution

【译自官方题解】

可以发现有些字符是确定的(即无法修改)。这些确定的字符满足以下几个条件。

  1. 所有的\(10\)是确定的。
  2. 如果字符串\(p\)是确定的且字符串\(q\)是确定的,那么字符串\(pq\)是确定的。
  3. 如果字符串\(p\)是确定的,那么字符串\(1p0\)是确定的。
  4. 根据以上三个性质可以推出,所有确定的字符串中0和1的个数相同
  5. 确定的字符串的最长不降子序列长度为该字符串长度的一半。具体的就是取全部的1或全部的0。

【下方内容为自己YY】

然后考虑如何具体实现。发现上面的5条性质(其实是前3条)与括号序列相同。所以实现就非常简单了。将1看做左括号,0看做右括号。最后将不能匹配的左括号全部变为0即可。

code

/*
* @Author: wxyww
* @Date: 2019-08-21 15:00:10
* @Last Modified time: 2019-08-21 15:01:55
*/
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<queue>
#include<vector>
#include<ctime>
#include<cmath>
#include<map>
#include<string>
using namespace std;
typedef long long ll;
const int N = 100000 + 100;
ll read() {
ll x = 0,f = 1; char c = getchar();
while(c < '0' || c > '9') {if(c == '-') f = -1;c = getchar();}
while(c >= '0' && c <= '9') {x = x * 10 + c - '0',c = getchar();}
return x * f;
}
char s[N];
int a[N],top;
int main() {
scanf("%s",s + 1);
int n = strlen(s + 1);
for(int i = 1;i <= n;++i) {
if(s[i] == '1') a[++top] = i;
else if(top) --top;
}
while(top) s[a[top--]] = '0';
printf("%s",s + 1);
return 0;
}

最新文章

  1. 使用VS Code 从零开始开发并调试.NET Core 应用程序
  2. mysql 擎特点
  3. BZOJ1880: [Sdoi2009]Elaxia的路线
  4. XML 和 List 互转类
  5. java9-8 局部内部类
  6. 怎么给ABBYY FineReader Mac导入图像
  7. 爬去知乎百万用户信息之UserTask
  8. C#正则提取HTML中img的url值
  9. [转]struct 用法深入探索
  10. zoj1610(线段树)
  11. 【Linux init】systemd 服务单元管理
  12. Java I/O---序列化接口Serializable
  13. 【Thinkphp 5】 整合邮箱类 phpmailer实现邮件发送
  14. Leetcode - 517 Super Washing Machines
  15. AVL平衡二叉树
  16. mybatis_generator_逆向工程的使用笔记
  17. .net core安装及初体验
  18. ECMAscript,DOM,BOM哪个比较重要
  19. JavaScript -基础- 函数与对象(三)Date对象
  20. 移动app传统测试流程优化

热门文章

  1. css3中calc、vw、vh、vmin、vmax 属性的应用及兼容性详解
  2. matlab练习程序(点云密度)
  3. Zookeeper分布式锁实战
  4. 安装torch
  5. Linux目录结构-下部
  6. 如何在Mac上配置iTerm2以及给ITerm2配置lrzsz
  7. requests库的使用、安装及方法的简单介绍
  8. HTTP 响应的分块传输
  9. 在生成.net core 3.0程序时不包含nuget库
  10. 谈谈EF Core实现数据库迁移