键盘输入一个高精度的正整数n(≤100位),去掉其中任意s个数字后剩下的数字按照原来的左右次序组成一个新的正整数。
编程对给定的n与s,寻找一种方案,使得剩下的数字组成的新数最小。
输入格式:
输入两个数字,分别为原始数n,要去掉的数字数s (s < n);
输出格式:
输出去掉s个数后最小的数。
输入样例:
178543 4
输出样例:
13
参考代码:
#include <stdio.h>
#include <string.h>
int main()
{
char s[101];
int n;
while (~scanf("%s %d", s, &n))
{
int len = strlen(s);
while (n--)
{
int i = 0;
while (s[i] <= s[i + 1] && i + 1 < len)
{
i++;
}
if (i != len - 1)
for (int j = i; j < len; j++)
s[j] = s[j + 1];
len--;
}
int i = 0;
while (s[i] == '0' && i < len)
i++;
if (i == len)
printf("0\n");
else
{
for (int j = i; j < len; j++)
printf("%c", s[j]);
printf("\n");
}
}
return 0;
}