题意:删去m个数,使剩下的数组成的数最小

题解 :贪心 , RMQ

RMQ解法,建st表找,用rmq找最小值的下标,注意点 ,因为最小值是区间最右最小值,所以应该改成 <= 而不是<

minpos[i][j] = b[minpos[i][j - ]] <= b[minpos[i + ( << (j - ))][j - ]] ? minpos[i][j - ] : minpos[i + ( << (j - ))][j - ];

且rmq查询也要同步

#include<iostream>
#include<cstdio>
#include<string>
#include<cmath>
#include<cstring>
using namespace std;
#define MAXN 20000 +9
#define MAXE 22
int h[MAXN],minpos[MAXN][MAXE];
int F_Min[MAXN][MAXE];
int N,Q;
int L,R;
// void RMQ_ST(){
// for(int i=1;i<=N;i++){
// mmax[i][0]=h[i]; // }
// int end_j=log(N+0.0)/log(2.0);
// int end_i;
// for(int j=1;j<=end_j;j++){
// end_i=N+1-(1<<j);
// for(int i=1;i<=end_i;i++){
// //mmax[i][j]=max(mmax[i][j-1],mmax[i+(1<<(j-1))][j-1]);
// mmin[i][j]=min(mmin[i][j-1],mmin[i+(1<<(j-1))][j-1]);
// }
// }
// } // int QueryMin(int L,int R){ // int k=log(R-L+1.0)/log(2.0);
// return min(mmin[L][k],mmin[R-(1<<k)+1][k]);
// } void RMQ_pos_init(int n, int b[]){
int i, j;
for (i = ; i <= n; i++) {
// maxpos[i][0] = i;
minpos[i][] = i;
}
for (j = ; ( << j) <= n; j++)
for (i = ; i + ( << j) - <= n; i++){
minpos[i][j] = b[minpos[i][j - ]] <= b[minpos[i + ( << (j - ))][j - ]] ? minpos[i][j - ] : minpos[i + ( << (j - ))][j - ];
//maxpos[i][j] = b[maxpos[i][j - 1]] > b[maxpos[i + (1 << (j - 1))][j - 1]] ? maxpos[i][j - 1] : maxpos[i + (1 << (j - 1))][j - 1];
} } int RMQ_pos_min(int s, int v, int b[]){
int k = (int)(log((v - s + )*1.0) / log(2.0));
return b[minpos[s][k]] <= b[minpos[v - ( << k) + ][k]] ? minpos[s][k] : minpos[v - ( << k) + ][k];
} char str[+ ];
int ans[ + ];
int main(int argc, char const *argv[])
{
int n;
while(~scanf("%s %d",&str,&n)){
int len = strlen(str);
int l = , r = n + ;
int m = len - n ;
int sum = ;
for(int i = ; i < len; i ++){
h[i + ] = str[i] - '';
}
// for(int i = 1;i )
RMQ_pos_init(len,h);
while(m--){
int i = l ;
int size = l ;
// for(;i <= r;i++){
// if((str[i] - '0') < (str[size] - '0')) size = i;
// }
//cout << l << " " << r << endl;
size = RMQ_pos_min(l,r,h);
//cout << size << endl;
ans[sum++] = h[size];
l = size + ;
r++;
}
int i = ;
while(ans[i] == && i < sum) i++;
if(i == sum) printf("");
else
// for(auto au : ans){
// printf("%d",ans );
// }
for(;i < sum; i++) printf("%d",ans[i]);
printf("\n"); }
return ;
}

RMQ

贪心解法

删除m个数字,相当于在里面从左往右取n-m个数字;所得数最小,也就是每次取得数字尽量小。那么,取得的第一个数字一定在区间[0,m]内,为什么呢?因为除了第一个数之外还要取n-m-1个数字,所以区间右边界最大只能是m,每次在区间里找最小的那个数(尽量靠左);依次类推,假设第一个数字取得的下标是index1,那么,第二个数字一定是在[index1+1,m+1]内取得;依次类推下去,右边界每次加1。当选取到了n-m个数字之后,也就找到了答案了~

#include<iostream>
#include<cstdio>
#include<string>
#include<cmath>
#include<cstring>
using namespace std;
#define MAXN 200000 +9
#define MAXE 22
int h[MAXN],mmax[MAXN][MAXE];
int N,Q;
int L,R;
void RMQ_ST(){
for(int i=;i<=N;i++){
mmax[i][]=h[i]; }
int end_j=log(N+0.0)/log(2.0);
int end_i;
for(int j=;j<=end_j;j++){
end_i=N+-(<<j);
for(int i=;i<=end_i;i++){
mmax[i][j]=max(mmax[i][j-],mmax[i+(<<(j-))][j-]);
// mmin[i][j]=min(mmin[i][j-1],mmin[i+(1<<(j-1))][j-1]);
}
}
}
int QueryMax(int L,int R){ int k=log(R-L+1.0)/log(2.0);
return max(mmax[L][k],mmax[R-(<<k)+][k]);
} char str[+ ];
int ans[ + ];
int main(int argc, char const *argv[])
{
int n;
while(~scanf("%s %d",&str,&n)){
int len = strlen(str);
int l = , r = n;
int m = len - n;
int sum = ;
while(m--){
int i = l;
int size = l;
for(;i <= r;i++){
if((str[i] - '') < (str[size] - '')) size = i;
}
ans[sum++] = str[size] - '';
l = size + ;
r++;
}
int i = ;
while(ans[i] == && i < sum) i++;
if(i == sum) printf("");
else
// for(auto au : ans){
// printf("%d",ans );
// }
for(;i < sum; i++) printf("%d",ans[i]);
printf("\n"); }
return ;
}

贪心

3183 RMQ / 贪心(坑成。。)的更多相关文章

  1. 【bzoj5073】[Lydsy1710月赛]小A的咒语 后缀数组+倍增RMQ+贪心+dp

    题目描述 给出 $A$ 串和 $B$ 串,从 $A$ 串中选出至多 $x$ 个互不重合的段,使得它们按照原顺序拼接后能够得到 $B$ 串.求是否可行.多组数据. $T\le 10$ ,$|A|,|B| ...

  2. hduacm 3183 rmq

    http://acm.hdu.edu.cn/showproblem.php?pid=3183 问题等价与取N-M个数,每次取的时候保证后面能取的个数足够,并且取的数最小  查询最小用rmq #incl ...

  3. HDU3183 RMQ/贪心

    A Magic Lamp Problem Description Kiki likes traveling. One day she finds a magic lamp, unfortunately ...

  4. hdu 3183 rmq+鸽巢原理

    题目大意: 给你一个数字字符串序列,给你要求删掉的数字个数m,删掉m个数使的剩下的数字字符串的之最小.并输出这个数字: 基本思路; 这题解法有很多,贪心,rmq都可以,这里选择rmq,因为很久没有写r ...

  5. hdu 3183(贪心)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3183 思路:比较前后两个相邻的字符,如果前面一个字符大于后面一个字符,就把它去掉. #include ...

  6. HDU 6034 Balala Power! (贪心+坑题)

    题意:给定一个 n 个字符串,然后问你怎么给 a-z赋值0-25,使得给定的字符串看成26进制得到的和最大,并且不能出现前导0. 析:一个很恶心的题目,细节有点多,首先是思路,给定个字符一个权值,然后 ...

  7. HDU 3183 A Magic Lamp(二维RMQ)

    第一种做法是贪心做法,只要前面的数比后面的大就把他删掉,这种做法是正确的,也比较好理解,这里就不说了,我比较想说一下ST算法,RMQ的应用 主要是返回数组的下标,RMQ要改成<=(这里是个坑点, ...

  8. [APIO / CTSC2007]数据备份 --- 贪心

    [APIO / CTSC 2007]数据备份 题目描述 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份. 然而数据备份的工作是枯燥乏味的,因此你想设计一个系统让不同的办公 ...

  9. CTSC2015&APIO2015滚粗记

    CTSC 这次CTSC的考试,觉得还是考出了自己该有的水平.虽然自己最后还是没有得到金牌,但是我觉得自己尽力了,也没有什么太大的遗憾.比起省选,自己在应试的方面又有了很大的进步. Day1是我主要捞分 ...

随机推荐

  1. Python---TKinter项目实战---屏保

    ### 项目分析 - 屏保可以自己启动,也可以手动启动 - 一旦敲击键盘或者移动鼠标后,或者其他的引发时间,则停止 - 如果屏保是一幅画的话,则没有画框 - 图像的动作是随机的,具有随机性,可能包括颜 ...

  2. 使用AnnotationConfigApplicationContext注册配置类

    1. AnnotationConfigApplicationContext功能 该类可以实现基于Java的配置类加载自定义在Spring的应用上下文的bean. 1.1 使用方式一:在构造方法中完成注 ...

  3. echart-折线图,数据太多想变成鼠标拖动和滚动的效果?以及数据的默认圈圈如何自定义圆圈的样式

    1.数据太多怎么办???想拖拽,想滑动 dataZoom: [ { type: 'slider', } ] dataZoom: [ { type: 'inside',  }] 两种功能都需要,还想调样 ...

  4. 解决json不能解析换行问题

    今天遇到一个问题,当我读取数据库中某条带换行的数据时,解析错误. 解决方法是在存入数据库时对数据做处理,把换行换成其他字符.代码如下: remark = remark.replace(/\n/g,&q ...

  5. Linux内核设计与实现 总结笔记(第十三章)虚拟文件系统

    一.通用文件系统接口 Linux通过虚拟文件系统,使得用户可以直接使用open().read().write()访问文件系统,这种协作性和泛型存取成为可能. 不管文件系统是什么,也不管文件系统位于何种 ...

  6. time,sys,os模块

      1.time模块 a:结构化时间:struct_time:通过time.localtime获取到一个时间对象,通过这个对象得到对象属性 ****localtime()如果没有参数,默认返回是一个时 ...

  7. 3D Computer Grapihcs Using OpenGL - 09 Enable Depth Test

    启用Depth Test OpenGL是个3D绘图API,也就是说不只有xy坐标轴,还有第三个坐标轴z,z轴的方向是垂直于屏幕,指向屏幕内. 靠近人眼的方向是负方向,标准化设备坐标的最小值是-1, 最 ...

  8. AI移动,缓慢转身设置(针对AI Character)

    AICharacter自身: Use Controller Rotation Yaw设为False Auto Possess AI 设为 Placed in World or Spawned Char ...

  9. Spring Cloud架构教程 (四)服务网关(路由配置)

    传统路由配置 所谓的传统路由配置方式就是在不依赖于服务发现机制的情况下,通过在配置文件中具体指定每个路由表达式与服务实例的映射关系来实现API网关对外部请求的路由. 没有Eureka和Consul的服 ...

  10. 通过java反射机制,修改年龄字段的值

    需求:将生日转为年龄 /** * 获取年龄值 */ public List getAgeInfo(List list) throws Exception { if (null == list || l ...