51Nod 1701 最后的机会
1701 最后的机会
给定一字符串S,S非空,由小写字母组成,设v为S中元音字母的个数,c为辅音字母的个数。"a", "e", "i", "o", "u"为元音字母。其余为辅音字母。如果元音字母没有超过辅音字母的2倍,即v≤2c则称S是好的字符串。
现在给定S,找出其中最长的好的子串的长度,以及个数。子串是由原串中连续的几个字符组成的。
样例解释:
在样例一中,最长的子串是他的自身“abo”。其它好的子串是“b”,“ab”,“bo”,但是都不是最长的。
在样例二中,最长的子串是“eis”。其它好的子串是“s”,“is”,但是都不是最长的。
输入
单组测试数据。
共一行字符串S(S非空且长度不大于2*10^5),由小写字母组成。其中"a", "e", "i", "o", "u"为元音字母。其余为辅音字母。
输出
输出两个整数,以空格隔开,分别表示最长的好的子串的长度和以及个数。如果没有好的子串则输出 "No solution" (没有引号)。 两个子串出现的位置不一样则称为是不同的子串。如果同一个子串在不同位置出了多次,则要统计多次。
输入样例
样例一
abo
样例二
oeis
输出样例
输出一
3 1
输出二
3 1
分析
对于符合的任意一段子序列(长度为len),假设其元音字符的个数为sum, 则依题意有sum<=2*(len-sum);
假如求出了元音字符数量的前缀和sum[]. 具体一点,假设这个子序列的左右下标为 i 和 j ,则有:
sum[j]-sum[i-1]<=2*((j-i+1)-(sum[j]-sum[i-1])) , 移项得 3*sum[j]-2*j<=3*sum[i-1]-2*(i-1), 想到可以记录一个
数组存储3*sum[i]-2*i的值。我们要求的最大长度即是满足上式的距离最远的i和j,只需再开一个数组rmin
(右边的最小值),用单调的思想处理一下,枚举i然后二分查找j,更新最大长度。。。
代码如下:
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<iostream>
using namespace std;
bool ok(char c)
{
    return c=='a'||c=='e'||c=='i'||c=='o'||c=='u';
}
char s[200005];
int ans1,ans2;
int sum[200005];
int T[200005];
int rmin[200005];
int main()
{
    //freopen("in.txt","r",stdin);
    scanf("%s",s);
    int n=strlen(s);
    for(int i=1;i<=n;i++)
        if(ok(s[i-1]))sum[i]=sum[i-1]+1;
        else sum[i]=sum[i-1];
    for(int i=1;i<=n;i++)
        T[i]=3*sum[i]-2*i;
    int tmp=0x3f3f3f3f;
    for(int i=n;i>=1;i--)
    {
        tmp=min(tmp,T[i]);
        rmin[i]=tmp;
    }
    for(int i=1;i<=n;i++)
    {
        int v=3*sum[i-1]-2*(i-1);
        int j=upper_bound(rmin,rmin+1+n,v)-rmin; j--;
        if(i<=j){ans1=max(ans1,j-i+1);}
    }
    for(int i=1,j=i+ans1-1;j<=n;i++,j++)
    {
        if(3*sum[j]-3*sum[i-1]<=2*(j-i+1))ans2++;
    }
    if(ans1==0){printf("No solution\n");}
    else printf("%d %d\n",ans1,ans2);
    return 0;
}
51Nod 1701 最后的机会的更多相关文章
- 51Nod 算法马拉松23 开黑记
		惨啊……虽然开了半天黑,但是还是被dalao们踩了…… 第二次开黑,还是被卡在rank20了,我好菜啊……= = 写一写比赛经过吧…… 看到题之后习惯性都打开,A~D看上去似乎并没有什么思路,F应该是 ... 
- 51nod  1625 贪心/思维
		http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1625 1625 夹克爷发红包 基准时间限制:1 秒 空间限制:13107 ... 
- HTPC家庭娱乐和XBOX未来发展畅想<另:创业工作机会>
		微软中国在上海举办新闻发布会,正式宣布Xbox One将于9月23日在中国开始销售,定价3699元起.这款早在2001年就发布的电视游戏机终于在经历了14年的等待后,进军中国大陆市场.此次Xbox O ... 
- 【51Nod 1244】莫比乌斯函数之和
		http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1244 模板题... 杜教筛和基于质因子分解的筛法都写了一下模板. 杜教筛 ... 
- 51Nod 1268 和为K的组合
		51Nod 1268 和为K的组合 1268 和为K的组合 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 给出N个正整数组成的数组A,求能否从中选出若干个,使 ... 
- 51Nod 1428 活动安排问题
		51Nod 1428 活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ... 
- 51Nod 1278 相离的圆
		51Nod 1278 相离的圆 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1278 1278 相离的圆 基 ... 
- 您还在招聘网上海量投简历然后等面试机会吗?那你已经OUT了。
		工作也可以来找我们.不行看完这篇. 从毕业到现在,换了2次工作.每次都在为招工组烦恼.找工作这个问题,不管是应届生还是职场老手.都面临一个问题就是找工作的平台.纵观目前的找工作的形式,主流的不外乎就两 ... 
- 风口之下,猪都能飞。当今中国股市牛市,真可谓“错过等七年”。 给你一个回顾历史的机会,已知一支股票连续n天的价格走势,以长度为n的整数数组表示,
		转自:http://www.cnblogs.com/ranranblog/p/5845010.html 风口之下,猪都能飞.当今中国股市牛市,真可谓“错过等七年”. 给你一个回顾历史的机会,已知一支股 ... 
随机推荐
- 22-MySQL DBA笔记-其他产品的选择
			第22章 其他产品的选择 本章将为读者介绍其他的数据库产品,主要是NoSQL产品的选择.读者在熟悉MySQL之外,也应该了解其他的数据库产品.本章的目的是给读者一个引导,如何选择一些NoSQL产品,而 ... 
- C# 延迟初始化 Lazy<T>
			概念:延时初始化重点是延时,用时加载,意思是对象在使用的时候创建而不是在实例化的的时候才创建. 延时加载主要应用的场景: 数据层(ADO.NET或Entity Framework等ORM,Java ... 
- 分析js跳出循环的几种方法
			Break语句: break语句会使运行的程序立刻退出包含在最内层的循环或者退出一个switch语句. 由于它是用来退出循环或者switch语句的, 所以只有当它出现在这些语句的时候, 这种形式的br ... 
- Python练习_初识函数_day9
			1. 1.作业 1,写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素,并将其作为新列表返回给调用者. 2,写函数,判断用户传入的对象(字符串.列表.元组)长度是否大于5. 3,写函数,检查 ... 
- Android Service的有关总结
			来自一位网友的评论 1.使用方式 startService 启动的服务 主要用于启动一个服务执行后台任务,不进行通信.停止服务使用stopService bindService 启动的服务 该方法启动 ... 
- React/react相关小结
			React React组件由React元素组成,React组件使用React.Component或React.PureComponent来生成:React元素使用JSX的语法来编写或使用React.c ... 
- webpack如何使用vue
			1.安装vue的包: cnpm i vue -S 2.在main.js中导入包 3.运行起来报错 3.1第一种解决办法: 3.2第二种解决办法: 让我们先回顾一下包的查找规则: //1.找项目根目录 ... 
- stm32 RS485 SP3485
			RS485 是半双工通信(2 线制) SP3485芯片的DE与RE短接在一起连接在STM32F1芯片的PG3上,通过PG3管脚就可以控制 SP3485的收发,当PG3=0时,为接收模式,当PG3=1时 ... 
- MYSQL8.0以上版本ROOT密码报错及修改
			在登录数据库过程中,如果遇到忘记root密码时,该如何解决? 1.使用管理员权限打开命令提示符,在命令行中输入: net stop mysql 2.待mysql服务停止后,输入: mysqld -- ... 
- c# 运算符和表达式
