解题思路:贪心算法
注意事项:理解题意后注意限制要求,可优化
参考代码:
def cor(str_) :
global cnt
lst = list(str_)
flag = 0 # 标志符
for num in range(len(lst) - 1) :
if lst[num] > lst[num + 1] :
lst[num] = 0
cnt += 1
flag = 1
break
str_ = ''.join(map(str, lst)).replace('0', '')
lst_.append(str_)
if flag == 0 : # 如果为0就是指这个结果里面每一个值都不比后一位小,就无法删减
str_ = str_[:base] # 所以此时只用把后面长于结果要求的位数删去即可
lst_.append(str_)
if cnt < k and len(str_) > base : # 如果删减的值不达标且现在的长度大于要求的结果长度就继续进行删减
cor(str_)
n = int(input())
for i in range(n) :
m, k = input().split()
k = int(k)
base = len(m) - k # 要求的结果长度
cnt = 0
lst_ = []
cor(m)
print(lst_[-1])
0.0分
1 人评分
Hello, world! (C语言代码)浏览:1322 |
奖学金 (C++代码)浏览:2057 |
数组输出 (C语言代码)--此题的题目描述有问题浏览:1846 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:495 |
【偶数求和】 (C++代码)浏览:746 |
C二级辅导-阶乘数列 (C语言代码)浏览:671 |
C语言程序设计教程(第三版)课后习题6.7 (C++代码)浏览:603 |
C语言程序设计教程(第三版)课后习题9.4 (C语言代码)浏览:3416 |
蛇行矩阵 (C语言代码)浏览:708 |
防御导弹 (C语言代码)浏览:2294 |