hdu 3183 A Magic Lamp RMQ ST 坐标最小值
hdu 3183 A Magic Lamp RMQ ST 坐标最小值
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3183
题目大意:
从给定的串中挑出来m个数使得剩余的数字最小,串的序列不能改变
思路:
- 将问题转化为求在n个数中挑选n-m个数,使之最小。假设最极端的情况,所有最大的数字都在左侧,占据了m个位置,那么我们需要挑选的最小的数字的第一位就是在m+1位上。依次类推,第二位在m+2位上,最后一位也就在原串的最后一位上。反过来,假设最大的数字都在右侧,占了m个位置。那么我们需要挑选的最小数字的最后一位就是在n-m位上,倒数第二位在n-m-1位上,最终最后一位就是在第一位上。至此,可以得到我们挑选最小数的第一位的取值范围就是[1,m+1]。类比可得,第二位取值范围[2,m+2],...。假设我们此时已经求出了第一位所在的位置x,那么第二位数字的范围就可以进一步缩小为[x+1,m+2],依次我们可以求出全部的数字。同时要注意,ST表中保存的是该段区间最小值的下标。
- ST在线 预处理O(nlogn) 查询O(1) 运行时间:15ms
- 这道题注意的细节有很多,写了很久才敢提交还是WA了3发。/(ㄒoㄒ)/~~要注意题中说n不会大于串的长度是不成立的,要来特判


代码:
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <math.h>
using namespace std;
const int maxn = 1005;
int minindex[maxn][10],data[maxn],res[maxn];
inline void init(int len) {
for(int i=1; i<=len; ++i) minindex[i][0]=i;
for(int j=1; j<=10; ++j) {
for(int i=1; i<=len; ++i) {
if((i+(1<<j)-1)<=len) {
int t1=minindex[i][j-1],t2=minindex[i+(1<<(j-1))][j-1];
if(data[t1]<=data[t2]) minindex[i][j]=t1;
else minindex[i][j]=t2;
}
}
}
}
inline int ask(int l, int r) {
int k=31-__builtin_clz(r-l+1);
int t1=minindex[l][k],t2=minindex[r-(1<<k)+1][k];
if(data[t1]<=data[t2]) return t1;
else return t2;
}
int main() {
char s[1005];
int n,len,l,r,ip1,ip2;
while(~scanf("%s %d",s,&n)) {
memset(minindex,0,sizeof(minindex));
len=strlen(s);
for(int i=0; i<len; ++i) {
data[i+1]=s[i]-'0';
}
if(n>=len) {
printf("0\n");
continue;
}
init(len);
len=len-n;
l=1,r=n+1;
ip2=1;
for(int i=1; i<=len; ++i) {
ip1=ask(l,r);
res[ip2]=data[ip1];
++ip2;
l=ip1+1;
++r;
}
ip2--;
for(l=1; l<=ip2; ++l) {
if(res[l]) break;
}
if(l>ip2) {
printf("0\n");
continue;
}
for(int i=l; i<=ip2; ++i) printf("%d",res[i]);
printf("\n");
}
return 0;
}
hdu 3183 A Magic Lamp RMQ ST 坐标最小值的更多相关文章
- 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)
题目链接:hdu 3183 A Magic Lamp 题目大意:给定一个字符串,然后最多删除K个.使得剩下的组成的数值最小. 解题思路:问题等价与取N-M个数.每次取的时候保证后面能取的个数足够,而且 ...
- HDU 3183 A Magic Lamp(RMQ问题, ST算法)
原题目 A Magic Lamp Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 3183 A Magic Lamp rmq或者暴力
A Magic Lamp Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Pro ...
- hdu 3183 A Magic Lamp(RMQ)
A Magic Lamp Time Limi ...
- hdu 3183 A Magic Lamp 【RMQ】
<题目链接> <转载于 >>> > 题目大意: 给出一个长度不超过1000位的数,求删去m位数字以后形成的最小的数字是多少. 解题分析: 分析:我们可以把题 ...
- HDU 3183 A Magic Lamp(二维RMQ)
第一种做法是贪心做法,只要前面的数比后面的大就把他删掉,这种做法是正确的,也比较好理解,这里就不说了,我比较想说一下ST算法,RMQ的应用 主要是返回数组的下标,RMQ要改成<=(这里是个坑点, ...
- hdu 3183 A Magic Lamp(给一个n位的数,从中删去m个数字,使得剩下的数字组成的数最小(顺序不能变),然后输出)
1.题目大意是,给你一个1000位的数,要你删掉m个为,求结果最小数. 思路:在n个位里面删除m个位.也就是找出n-m个位组成最小数 所以在区间 [0, m]里面找最小的数.相应的下标标号i 接着找区 ...
- hdu 3183 A Magic Lamp 贪心
#include <stdio.h> #include <string.h> #include <iostream> #include <algorithm& ...
随机推荐
- 实验之-----------修改oracle实例名
--查询当前数据库实例名称: SQL> select instance_name,status from v$instance; INSTANCE_NAME STATUS------------ ...
- React UI 组件库uiw v1.2.8 发布
uiw 高品质的UI工具包,基于React 16+的组件库.
- DataTable数据修改,换列
增加列 DataTable table= new DataTable(); table.Columns.Add("ID", type ...
- 关于CSS3 object-position/object-fit属性的使用
object-position/object-fit属性一般用在替换元素上. 什么叫替换元素? 不是所有元素都叫"替换元素".在CSS中,"替换元素"指的是: ...
- OpenCV Image Watch 调试插件
昨晚偶然发现vs2012的这个很神奇的插件,对于经常使用opencv的人来说,这个插件无疑是我们的调试神器.今天马上下载试用,感觉超级棒!~以后要想查看图像结果,不用再imshow了! Image W ...
- enum(枚举类型)
可以使用枚举类型声明代表整数常量的符号名称. 通过enum,创建一个新类型,并指定它可以拥有的值.(就像平常用一个整形变量,我们指定它等于0的时候代表什么,1呢,2呢...而通过枚举,就增加了程序的可 ...
- 【转载】XSS学习笔记
XSS的分类 非持久型 非持久型XSS也称反射型XSS.具体原理就是当用户提交一段代码的时候,服务端会马上返回页面的执行结果.那么当攻击者让被攻击者提交一个伪装好的带有恶意代码的链接时,服务端也会立刻 ...
- 初学者最易懂的git教程在这里!
一.git简介: Linux创建了Linux,但是Linux的发展壮大是由世界各地的热心志愿者参与编写的?那么那么多份的代码是怎么合并的呢?之前是在2002年以前,世界各地的志愿者把源代码文件通过di ...
- [MYSQL] 记一次MySQL性能调优
最近在做数据迁移工作,已有一堆数据文件,要把这些数据文件写到MySQL 数据库里面去. MySQL数据库上架了一层服务接口,可以直接调用.博主写了一个迁移程序,放在服务器A上. *********** ...
- HDU3045 Picnic Cows (斜率DP优化)(数形结合)
转自PomeCat: "DP的斜率优化--对不必要的状态量进行抛弃,对不优的状态量进行搁置,使得在常数时间内找到最优解成为可能.斜率优化依靠的是数形结合的思想,通过将每个阶段和状态的答案反映 ...