c语言区一个数的最高位,C语言:删数问题

例30  删数问题

问题描述

从键盘输入一个高精度正整数num(num不超过250位),任意去掉S个数字后剩下的数字按原先后次序将组成一个新的正整数。编写一个程序,对给定的num和s,寻找一种方案,使得剩下的数字组成的新数最小。

输入格式

num (高精度的正整数)和S(需要删除的数字个数)。

输出格式

最后剩下的最小数。

输入样例

51428397

5

输出样例

123

(1)编程思路。

由于键盘输入的是一个高精度正整数num(num不超过250位),因此用字符串数组来进行存储。

为了尽可能地逼近目标,选取的贪心策略为:每一步总是选择一个使剩下的数最小的数字删去,即按高位到低位的顺序搜索,若各位数字递增,则删除最后一个数字,否则删除第一个递减区间的首字符。然后回到串首,按上述规则再删除下一个数字。重复以上过程s次,剩下的数字串便是问题的解了。

也就是说,删数问题采用贪心算法求解时,采用最近下降点优先的贪心策略:即x1

另外,按这个方法删除s位后,要注意去掉结果中可能存在的前导0。

(2)源程序。

#include

#include

int main()

{

char num[251]={'\0'};

int s,i,j;

scanf("%s",num);

scanf("%d",&s);

while (s>0)    // 循环s次,每次删除一个数字

{

i=0;          // 每次删除后从头开始搜寻待删除数字

while (num[i]!='\0' && num[i]<=num[i+1])

i++;

for(j=i;j

num[j]=num[j+1];   // 将位置i处的数字删除

s--;

}

i=0;

while(num[i]=='0') i++;  //处理前导0

if (num[i]=='\0') printf("0\n");

else  printf("%s\n",

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值