1.题目大意是,给你一个1000位的数,要你删掉m个为,求结果最小数。

思路:在n个位里面删除m个位。也就是找出n-m个位组成最小数

所以在区间 [0, m]里面找最小的数。相应的下标标号i

接着找区间 [i+1,m++]里面的最小数。对于下标为ii

接着找区间 [ii+1,m++]里面的最小数……

这样就会找n-m个数了。区间这样安排的目的是为了保证取出来的数的顺序。

2代码:

#include<cstdio>
#include<cstring>
#include<cmath>
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std; char s[10005];
int a[10005];
int an[10005];
int ST[10005][20];
int n,m; void make_ST()//记录的是最小值的下标
{
for(int j=1; (1<<j)<=n; j++)
{
for(int i=1; (i+(1<<j)-1)<=n; i++)
{
if(a[ST[i][j-1]]<=a[ST[i+(1<<(j-1))][j-1]])//得取等号,使得两个数相等的时候取下标小的
ST[i][j]=ST[i][j-1];
else
ST[i][j]=ST[i+(1<<(j-1))][j-1];
}
}
} int Query(int l,int r)
{
int k=floor(log2(r-l+1));
int ans;
if(a[ST[l][k]]<=a[ST[r-(1<<k)+1][k]])
ans=ST[l][k];
else
ans=ST[r-(1<<k)+1][k];
return ans;
} int main()
{
while(scanf("%s%d",s,&m)==2)
{
n=strlen(s);
for(int i=0; i<n; i++)
{
a[i+1]=(s[i]-'0');
ST[i+1][0]=i+1;
}
make_ST();
int t=1;
int temp=1;
for(int i=m+1; i<=n; i++) //找n-m个数,每次从[t,i]中找最小的
{
t=Query(t,i);
an[temp++]=a[t++];
}
t=1;
while(t<temp&&an[t]==0)
t++;
if(t>=temp)
printf("0\n");
else
{
for(int i=t; i<temp; i++)
printf("%d",an[i]);
printf("\n");
}
}
return 0;
}

最新文章

  1. 关于sharedPreferences的使用
  2. Balsamiq Mockups 注册码
  3. linux 常用技巧
  4. Eclipse_调试技巧
  5. Windows 下安装项目管理工具 Redmine 1.1.2
  6. eBay 消息发送(1)
  7. Java数组运算
  8. intervention/image intervention/imagecache
  9. 将salt取到的数据处理
  10. Magento:Paypal付款不成功返回后不要清空购物车产品的解决方案
  11. bzoj1855
  12. 【转】Android ListView长按事件触发点击事件
  13. 找工作笔试面试那些事儿(16)---linux相关知识点(1)
  14. 给Myeclipse配置tomcat服务器
  15. 初学python之路-day03
  16. μCOS-Ⅲ——常用注意事项
  17. gitlab 安装和使用
  18. [CTSC2017]吉夫特
  19. 一个完整的成年果蝇大脑的电子显微镜图谱 | A Complete Electron Microscopy Volume of the Brain of Adult Drosophila melanogaster
  20. 导出无法正常启动的VMware虚拟机中的文件

热门文章

  1. Linux下使用vi命令后退出方式
  2. OpenJudge-百练-2755
  3. css搞定所有垂直居中问题
  4. 了解DOM
  5. 安装mysql后无法找到临时密码的解决方案
  6. vsftpd系统用户配置详解
  7. xtu summer individual 2 E - Double Profiles
  8. hexo干货系列:(二)hexo主题下载及配置
  9. PTA 04-树5 Root of AVL Tree (25分)
  10. PTA 03-树2 List Leaves (25分)