解题思路:贪心算法
注意事项:理解题意后注意限制要求,可优化
参考代码:
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 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复