hduacm 3183 rmq
http://acm.hdu.edu.cn/showproblem.php?pid=3183
问题等价与取N-M个数,每次取的时候保证后面能取的个数足够,并且取的数最小 查询最小用rmq
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring> using namespace std; const int maxn = + ; int N,M,d[maxn][];
char s[maxn]; struct RMQ{
void init()
{
N = strlen(s);
for (int i = ;i<N;i++)
d[i][] = s[i];
for (int k = ;(<<k)<=N;k++)
{
for (int i = ;i<N;i++)
d[i][k] = min(d[i][k-],d[i+(<<(k-))][k-]); }
}
int query(int L,int R)
{
int k = ;
while (<<(k+)<=R-L+) k++;
return min(d[L][k],d[R-(<<k)+][k]);
}
}; RMQ rmq; int main()
{
while (~scanf("%s%d",s,&M))
{
rmq.init();
M = N - M;
int mv = ;
bool flag = true;
for (int i = M;i;i--)
{
int c = rmq.query(mv,N-i);
while (mv<N&&s[mv]!=c) mv++;
mv++;
if (c==''&&flag)
continue;
flag = false;
printf("%c",c); }
if (flag)
printf("");
printf("\n");
}
return ;
}
hduacm 3183 rmq的更多相关文章
- 3183 RMQ / 贪心(坑成。。)
		
题意:删去m个数,使剩下的数组成的数最小 题解 :贪心 , RMQ RMQ解法,建st表找,用rmq找最小值的下标,注意点 ,因为最小值是区间最右最小值,所以应该改成 <= 而不是< mi ...
 - hdu 3183 rmq+鸽巢原理
		
题目大意: 给你一个数字字符串序列,给你要求删掉的数字个数m,删掉m个数使的剩下的数字字符串的之最小.并输出这个数字: 基本思路; 这题解法有很多,贪心,rmq都可以,这里选择rmq,因为很久没有写r ...
 - hdu 3183 A Magic Lamp(RMQ)
		
题目链接:hdu 3183 A Magic Lamp 题目大意:给定一个字符串,然后最多删除K个.使得剩下的组成的数值最小. 解题思路:问题等价与取N-M个数.每次取的时候保证后面能取的个数足够,而且 ...
 - hdu 3183 A Magic Lamp RMQ ST 坐标最小值
		
hdu 3183 A Magic Lamp RMQ ST 坐标最小值 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3183 题目大意: 从给定的串中挑 ...
 - HDU 3183 - A Magic Lamp - [RMQ][ST算法]
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3183 Problem DescriptionKiki likes traveling. One day ...
 - HDU 3183.A Magic Lamp-区间找最小值-RMQ(ST)
		
A Magic Lamp Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
 - HDU 3183:A Magic Lamp(RMQ)
		
http://acm.hdu.edu.cn/showproblem.php?pid=3183 题意:给出一个数,可以删除掉其中m个字符,要使得最后的数字最小,输出最后的数字(忽略前导零). 思路:设数 ...
 - hduacm 2888  ----二维rmq
		
http://acm.hdu.edu.cn/showproblem.php?pid=2888 模板题 直接用二维rmq 读入数据时比较坑爹 cin 会超时 #include <cstdio& ...
 - HDU 3183 A Magic Lamp(二维RMQ)
		
第一种做法是贪心做法,只要前面的数比后面的大就把他删掉,这种做法是正确的,也比较好理解,这里就不说了,我比较想说一下ST算法,RMQ的应用 主要是返回数组的下标,RMQ要改成<=(这里是个坑点, ...
 
随机推荐
- netty概念
			
Netty的ChannelFuture在Netty中的所有的I/O操作都是异步执行的,这就意味着任何一个I/O操作会立刻返回,不保证在调用结束的时候操作会执行完成.因此,会返回一个ChannelFut ...
 - [转载] 新兵训练营系列课程——平台服务部署及Web框架
			
原文: http://weibo.com/p/1001643875679132642345 大纲 微博平台主要负责微博基础功能.接下来将会介绍 平台的作用,以及服务提供的形式 平台Web服务的部署 平 ...
 - linux虚拟机安装
			
1.真实机第一次安装必须先搞f2进入boot从光盘启动,虚拟机不用 进入的时候五个选项Install or upgrade an existing system:安装或升级现有系统Install sy ...
 - poj2780Linearity(多点共线)
			
链接 判断最多多少点在一条直线上, 可以枚举每一个点为坐标系的原点,其它点变成相应的位置,然后求得过原点及其点的斜率,排序找一下最多相同的. #include <iostream> #in ...
 - Oracle正则表达式函数:regexp_like、regexp_substr、regexp_instr、regexp_replace
			
Oracle正则表达式函数:regexp_like.regexp_substr.regexp_instr.regexp_replace --去掉所有特殊字符,只剩字母 SELECT REGEXP ...
 - IIS Express简介
			
当前程序员只能通过下面两种Web服务器之一来开发和测试ASP.NET网站程序: 1. Visual Studio自带的ASP.NET开发服务器(webdev.exe). 2. Windows自带的II ...
 - 发现easyui-accordion一个bug,在ie6、ie7不兼容性问题
			
当设置全局css文件单元格样式为下面时 td{ word-break: break-all; word-wrap: break-word;} easyui-accordion在ie6.ie7上面会出现 ...
 - hibernate配置文件中的catalog属性
			
在hibernate表的映射文件中 <hibernate-mapping> <class name="com.sooyie.hibernate.orm.Link&qu ...
 - JSP中RequestDispatcher的用法
			
RequestDispatcher是一个Web资源的包装器,可以用来把当前request传递到该资源,或者把新的资源包括到当前响应中.RequestDispatcher接口中定义了两个方法:inclu ...
 - PHP 用文件流方式展示图片
			
public function index(){ $img = 'http://img.pf.loc/static/images/2016/05/24/21d98edf98bd6c30afe1c838 ...