码迷,mamicode.com
首页 > 其他好文 > 详细

给定一个正整数,实现一个方法求出离该整数最近的大于自身的 换位数 <把一个整数各个数位进行全排列>

时间:2018-05-21 19:39:01      阅读:277      评论:0      收藏:0      [点我收藏+]

标签:too   iter   大于   bsp   name   数位   ror   erro   没有   

"""
给定一个正整数,实现一个方法求出离该整数最近的大于自身的 换位数 -> 把一个整数各个数位进行全排列
"""

# 使用 permutations() 方法实现
import itertools


def full_arrangement(num):
  my_str = ‘‘
  my_list = []
  permutation = list(itertools.permutations(str(num), len(str(num))))
  for p in permutation:
    for i in range(len(p)):
      my_str += p[i]
      if len(my_str) == len(str(num)):
        my_num = int(my_str)
        if my_num > num:
          my_list.append(my_num)
        my_str = ‘‘
  return my_list


if __name__ == ‘__main__‘:
num = int(input(‘输入一个正整数:‘))
my_list = full_arrangement(num)
# 离该整数最近的大于自身的 换位数
try:
  digits = min(my_list)
  print(digits)
except ValueError as e:
  print(‘该正整数没有比自身大的换位数‘)

给定一个正整数,实现一个方法求出离该整数最近的大于自身的 换位数 <把一个整数各个数位进行全排列>

标签:too   iter   大于   bsp   name   数位   ror   erro   没有   

原文地址:https://www.cnblogs.com/changqing8023/p/9068404.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!