【洛谷-P1106的Python方法】

题目描述

键盘输入一个高精度的正整数 NN(不超过 250250 位),去掉其中任意 kk 个数字后剩下的数字按原左右次序将组成一个新的非负整数。编程对给定的 NN 和 kk,寻找一种方案使得剩下的数字组成的新数最小。

输入格式

输入两行正整数。

第一行输入一个高精度的正整数 nn。

第二行输入一个正整数 kk,表示需要删除的数字个数。

输出格式

输出一个整数,最后剩下的最小数。

输入输出样例

输入 #1                                        输出 #1

175438                        13
4

解题思路

  • 输入str类型的高精度正整数nn,int类型正整数k
  • 将字符串切片并转为int类型存入列表
  • 改变列表为升序形式,弹出后面k个大数
  • 输出剩余列表元素(注意加上end = "" 将元素连成一块)

代码

num = input()#输入字符串
k = int(input())#输入整数
num_list = []#切片后存入的列表
for i in range(len(num)):
    num_list.append(int(num[i]))#切片
num_list.sort(reverse = False)#升序排序
for i in range(k):
    num_list.pop()#弹出末尾k个大数
for i in range(len(num_list)):
    print(num_list[i],end = "")#输出数,注意中间连接没有空格

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值