题意

求长度为n的01串中1占总长(大于L)的比例最大的一个子串起点和终点。

分析

前缀和s[i]保存前i个数有几个1,[j+1,i] 这段区间1的比例就是(s[i]-s[j])/(i-j),于是问题转换为找斜率最大的两个点。

如图,加入j时,就要去掉b1、b2,才能维护斜率的单调递增。

以队列里的点做起点,i 结尾的线段斜率最大的是 i和队列里点组成的下凹线的切线。切点前的点就不会再用到了,因为i后面的点和他们的斜率也将不如和这个切点的斜率。

数形结合,斜率优化,单调队列。

代码

#include<deque>
#include<cstdio> using namespace std; deque<int> q; int s[];
int ansl,ansr; int great(int a,int b,int c,int d)//求ab斜率是否大于cd斜率
{
return (s[a]-s[b])*(c-d) - (s[c]-s[d])*(a-b);
} int main()
{
int t,L,n,a;
scanf("%d",&t);
while(t--)
{
scanf("%d%d ",&n,&L);
char cc;
for(int i=;i<=n;i++){
cc=getchar();
s[i]=s[i-]+cc-'';//这样读才不会超时
}
q.clear();
ansl=;
ansr=L;
for(int i=L; i<=n; i++)//以i做线段右端点
{
int j=i-L;
while(q.size()>)//把j作为线段左端点,加入单调队列
{//(单调指斜率单调递增)
int b1=q[q.size()-];//倒数第1个
int b2=q[q.size()-];//倒数第2个
if(great(b1,b2,j,b1)>)//如果b1b2斜率比jb1更大
q.pop_back();//弹出b1,维护单调性
else break;//
}
q.push_back(j);//j入队
while(q.size()>)//去掉队前头不优的起点(线段左端点)
{//因为和i斜率最大的是下凹线的切点,切点前的点不优
if(great(i,q[],i,q[])<=)//以i做终点 q[0]i的斜率小于q[1]i的斜率
q.pop_front();//就弹出队头
else break;
}
int tmp=great(i,q[],ansr,ansl);//i和切点的斜率,也就是最大斜率
if(tmp> || tmp== && i-q[]<ansr-ansl)
{
ansl=q[];//左端点更新
ansr=i;//右端点更新
}
}
printf("%d %d\n",ansl+,ansr);//存的是左端点右1的点,故输出时+1
}
return ;
}

  

【UVA 1451】Average的更多相关文章

  1. 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵

    偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...

  2. 【贪心+中位数】【UVa 11300】 分金币

    (解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...

  3. 【UVa 10881】Piotr's Ants

    Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...

  4. 【UVa 116】Unidirectional TSP

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  5. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  6. 【UVA 437】The Tower of Babylon(记忆化搜索写法)

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 【uva 1025】A Spy in the Metro

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  8. 【Uva 11584】Partitioning by Palindromes

    [Link]:https://cn.vjudge.net/contest/170078#problem/G [Description] 给你若干个只由小写字母组成的字符串; 问你,这个字符串,最少能由 ...

  9. 【Uva 11400】Lighting System Design

    [Link]: [Description] 你要构建一个供电系统; 给你n种灯泡来构建这么一个系统; 每种灯泡有4个参数 1.灯泡的工作电压 2.灯泡的所需的电源的花费(只要买一个电源就能供这种灯泡的 ...

随机推荐

  1. jquery实现整屏翻屏效果:jquery.mousewheel(一)

    实现整屏上下翻效果:需加载的js <script type="text/javascript" src="js/jquery-1.8.3.min.js"& ...

  2. HDU 1698 & UESTC 1228 Just a hook

    算是线段树中的一道水题了,必须用到懒操作,否则会超时.或者也可以刚开始不计算和,只更新节点,最后算整个线段的颜色和. 1.懒操作法 /* 908ms 3448KB in HDU OJ*/ #inclu ...

  3. android studio没有org.apache.http.client.HttpClient;等包问题 解决方案

    以前用Eclipse做Android开发工具一直使用apache的http做网络请求,最近换用了Android studio发现没有办法引用apache的包,下面是我引用的步骤

  4. rm 删除带空格的文件或者目录

    1. 信息来源 from man rm, 绝对真实有效 比较删除一个 windows盘符下的 “Program Files“ 目录, 直接rm Program Files 会直接报错, 需要修改为如下 ...

  5. iOS开发如何提高(from 唐巧的博客)

    http://blog.devtang.com/blog/2014/07/27/ios-levelup-tips/

  6. 使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇

    调用jQuery的ajax方法时,jQuery会根据post或者get协议对参数data进行序列化; 如果提交的数据使用复杂的json数据,例如: {userId:32323,userName:{fi ...

  7. Yii提供的Htmler助手checkboxList可自定义Checkbox输出格式

    foreach($catetags as $cate){ echo Html::checkboxList('category_id','',$cate,['item'=>'customCheck ...

  8. WP老杨解迷:如何获得更多的应用评价和解读内容刷新

    Windows Phone的市场评论功能研究的时间比较长,只是这一功能,估计就能写一篇论文,我曾搞过多款评论数超高的游戏,其中<少林塔防>是重量级的作品,至今稳坐最高评分第一把交椅,如果不 ...

  9. C#根据IP地址和子网掩码计算广播地址

    using System.Net; /// <summary> /// 获得广播地址 /// </summary> /// <param name="ipAdd ...

  10. linux 高级编程之库的使用

    一.静态库与动态库 静态库: .a .lib 动态库: .so .dll 差别(静态库中的代码在链接时就已经复制到可执行文件中,执行时不再依赖库,不会自动使用升级后的库,需要重新产生可执行文件. 动态 ...