如何对数字中的数字进行排序?

时间:2009-08-19 16:39:14

标签: python numbers

我正在尝试在Python中创建一个简单的脚本,它接受一个数字并保存在一个变量中,按升序和降序对数字进行排序,并将两者保存在单独的变量中。实施Kaprekar's constant

这可能是一个非常无聊的问题。但我是新手,我在Google上找不到任何可以帮助我的东西。我找到的一个网站试图解释一种使用列表的方式,但它没有很好地解决。

5 个答案:

答案 0 :(得分:12)

按升序和降序对数字排序:

ascending = "".join(sorted(str(number)))

descending = "".join(sorted(str(number), reverse=True))

像这样:

>>> number = 5896
>>> ascending = "".join(sorted(str(number)))
>>>
>>> descending = "".join(sorted(str(number), reverse=True))
>>> ascending
'5689'
>>> descending
'9865'

如果你需要它们再次成为数字(而不仅仅是字符串),请在它们上面调用int()

>>> int(ascending)
5689
>>> int(descending)
9865

答案 1 :(得分:3)

>>> x = [4,5,81,5,28958,28] # first list
>>> print sorted(x)
[4, 5, 5, 28, 81, 28958]
>>> x
[4, 5, 81, 5, 28958, 28]
>>> x.sort() # sort the list in place
>>> x
[4, 5, 5, 28, 81, 28958]
>>> x.append(1) # add to the list
>>> x
[4, 5, 5, 28, 81, 28958, 1]
>>> sorted(x)
[1, 4, 5, 5, 28, 81, 28958]

正如其他许多人所指出的那样,你可以按照以下方式对数字进行排序:

>>> int(''.join(sorted(str(2314))))
1234

这几乎是最标准的方式。

反转一个数字?在尾随零的数字中不能很好地工作。

>>> y = int(''.join(sorted(str(2314))))
>>> y
1234
>>> int(str(y)[::-1])
4321

[::-1]表示法表示迭代将以相反的顺序遍历。

答案 2 :(得分:2)

正如Mark Rushakoff在他的回答中已经提到过(但没有解决),str(n)不会处理带有前导零的数字nKaprekar's operation需要它。 hughdbrown的答案同样不适用于前导零。

确保使用四个字符的字符串的一种方法是使用zfill字符串方法。例如:

>>> n = 2
>>> str(n)
'2'
>>> str(n).zfill(4)
'0002'

您还应该知道,在3之前的Python版本中,数字文字中的前导零表示八进制:

>>> str(0043)
'35'
>>> str(0378)
  File "<stdin>", line 1
    str(0378)
           ^
SyntaxError: invalid token

在Python 3中,0043根本不是有效的数字文字。

答案 3 :(得分:1)

我不知道python语法,但是一般来说,我会将输入字符串转换为字符数组,它们会对字符数组进行排序,最后将其输出。

答案 4 :(得分:0)

以下是Perl中标题问题的答案,偏向于对Kaprekar算法的4位数字进行排序。在示例中,将“shift”替换为要排序的数字。它将4位数字中的数字排序为前导0($ asc按升序排序,$ dec下降),并输出前导0的数字:

my $num = sprintf("%04d", shift);
my $asc = sprintf("%04d", join('', sort {$a <=> $b} split('', $num)));
my $dec = sprintf("%04d", join('', sort {$b <=> $a} split('', $num)));