就是从n位数中取出n-d个数字按顺序排成一排组成一个新数使得其最大

算法:

从前往后确定每一位。找第i位时,要求后面留下d-i位的空间,

因此第i位应该从第i-1位原来位置+1到第d+i位寻找

用线段树确定区间最大值(其实直接用优先队列就行了,可能会多一些多余的出队操作)

更好的算法:

***引用

后来看到一个博客写的特别巧妙,

每读取一个字符,如果ans中有字符,且如果删除一个字符后面的数字数量依然够的话,

并且ans中最后一个数字比新读取的小,那么删除最后一个字符,把新读取的字符加入ans.

http://www.cnblogs.com/jihe/p/4883573.html***

#include<cstdio>
#include<algorithm>
using namespace std;
int c[300010];
int ans[300010];
int n,d;
struct Node
{
int lc,rc,l,r,maxpos;
}node[1000010];
int num_node;
int getnode()
{
return num_node++;
}
int build(int l,int r)
{
int _tmp=getnode();
node[_tmp].l=l;
node[_tmp].r=r;
if(l==r)
{
node[_tmp].maxpos=l;
return _tmp;
}
int m=(l+r)>>1;
node[_tmp].lc=build(l,m);
node[_tmp].rc=build(m+1,r);
if(c[node[node[_tmp].lc].maxpos]<c[node[node[_tmp].rc].maxpos])
node[_tmp].maxpos=node[node[_tmp].rc].maxpos;
else
node[_tmp].maxpos=node[node[_tmp].lc].maxpos;
return _tmp;
}
int query(int L,int R,int nownode)
{
int l=node[nownode].l;
int r=node[nownode].r;
if(L<=l&&r<=R)
return node[nownode].maxpos;
int t,ans=n+1,m=(l+r)>>1;
if(L<=m)
{
t=query(L,R,node[nownode].lc);
if(c[ans]<c[t])
ans=t;
}
if(R>m)
{
t=query(L,R,node[nownode].rc);
if(c[ans]<c[t])
ans=t;
}
return ans;
}
int main()
{
int i,t;
scanf("%d%d",&n,&d);
while(n!=0&&d!=0)
{
num_node=0;
t=0;
for(i=1;i<=n;i++)
scanf("%1d",&c[i]);
c[n+1]=-1;
build(1,n);
for(i=1;i<=n-d;i++)
{
t=query(t+1,d+i,0);
printf("%d",c[t]);
}
printf("\n");
scanf("%d%d",&n,&d);
}
return 0;
}

从一个n位数中选出m位按顺序组成新数并使其最大 || Erasing and Winning UVA - 11491的更多相关文章

  1. 用MFC完成一个简单的猜数字游戏: 输入的四位数中,位置和数字都正确为A,数字相同而位置不同的为B。

    最近学习了MFC一些比较基础的知识,所以打算通过做一个简单的数字游戏来理解MFC的流程并进一步熟悉其操作. 在这里,我做了一个猜数字的小游戏.第一步当然是设计主界面,先给大家展示一下游戏界面: 主界面 ...

  2. 编写Java程序_输入一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

    要求: 输入一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同. 实现代码: package kaoshi; import java.util.Scanner; pu ...

  3. [转]趣题:一个n位数平均有多少个单调区间?---- From Matrix67

    考虑这么一个 14 位数 02565413989732 ,如图所示,它的数字先逐渐变大,然后开始变小,再变大,再变小,再变大,再变小.我们就说,它一共包含了 6 个单调区间.我们的问题就是:一个 n ...

  4. 将十进制数转为一个n位数的密码(每位都是个m进制数)

    例如一个6位数的10进制密码,共有106个密码,如果把每个6位数的密码编成号就是[0,106-1].这是十进制的情况,即6个位,每个位有10种选择.如果要遍历所有密码,需要6重for循环,每个循环10 ...

  5. 数字序列中某一位数字(《剑指offer》面试题44)

    由于这道题目在牛客上没有,所以在此记录一下. 一.题目大意: 数字以0123456789101112131415…的格式序列化到一个字符序列中.在这个序列中,第5位(从0开始计数,即从第0位开始)是5 ...

  6. ZT 计算一个无符整数中1Bit的个数(1) 2010-04-20 10:52:48

    计算一个无符整数中1Bit的个数(1) 2010-04-20 10:52:48 分类: C/C++ [转]计算一个无符整数中1Bit的个数(1)   Count the number of bits ...

  7. C/C++中的64位整数

    C/C++中的64位整数(__int64 and long long) 在做ACM题时,经常都会遇到一些比较大的整数.而常用的内置整数类型常常显得太小了:其中long 和 int 范围是[-2^31, ...

  8. 【Offer】[44] 【数字序列中某一位的数字】

    题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 数字以0123456789101112131415..的格式序列化到一个字符序列中.在这个序列中,第5位(从0开始计数)是5,第13位是 ...

  9. 剑指offer——46数字序列中某一位的数字

    题目: 数字以0123456789101112131415…的格式序列化到一个字符序列中.在这个序列中,第5位(从0开始计数)是5,第13位是1,第19位是4,等等.请写一个函数,求任意第n位对应的数 ...

随机推荐

  1. 怎样搭建svn本地server,管理本地的代码

    搭建svn本地server,以下是详细的步骤介绍. 一.准备工作 1.下载svnserver端:Subversion. 到官方站点(http://s version.tigris.org/)下载最新的 ...

  2. &lt;十二&gt;读&lt;&lt;大话设计模式&gt;&gt;之状态模式

    对于状态模式,<<大话设计模式>>是以人从上班到下班到加班的状态来展开讲述的.状态模式事实上就是某一个对象在某个过程或者时间的一个状态记录,可是这个状态的顺序不能发生变化.在程 ...

  3. UI UISearchBar UISearchDisplayController实现搜索条、解析颜色

    本文转载至 http://blog.sina.com.cn/s/blog_bf2d33bd01017q6l.html @interface ThirdViewController : UIViewCo ...

  4. sqlldr trailing nullcols

    由于要导入到tmp_content表的一些列(列:要导入的源文件txt or csv文件)为空,也,按理讲我当时另存为(在windows处理)csv,以,分隔.就是这个列没有内容,也该显示, ,之类的 ...

  5. 使用Apache Ant合并多个jar

    Apache Ant下载地址 下载解压后进入bin目录,并在此目录打开cmd 在cmd中运行ant,运行结果为: Buildfile: build.xml does not exist! Build ...

  6. poj 1821 Fence(单调队列优化DP)

    poj 1821 Fence \(solution:\) 这道题因为每一个粉刷的人都有一块"必刷的木板",所以可以预见我们的最终方案里的粉刷匠一定是按其必刷的木板的顺序排列的.这就 ...

  7. Linux内核中工作队列的使用work_struct,delayed_work【转】

    本文转载自:http://blog.csdn.net/zahuopuboss/article/details/43268983 初始化工作队列 调度工作队列 取消工作队列 #include <l ...

  8. html5--6-57 阶段练习6-折叠导航栏

    html5--6-57 阶段练习6-折叠导航栏 实例 @charset="UTF-8"; *{ ; ; } h3+div{ ; overflow: hidden; transiti ...

  9. Vim Vundle YouCompleteMe

    /************************************************************************************** * Vim Vundle ...

  10. liunx命令之【查看某个端口号的使用情况】

    第一:查看端口占用情况的命令:lsof -i:<端口号>