如何检查第N个索引是否大于前一个索引

2024-04-26 04:04:42 发布

您现在位置:Python中文网/ 问答频道 /正文

我想运行一个从0到1000的循环,我想打印比前一个数字低的数字“例如:123 3大于2,2大于1,所以打印123”我尝试了从1到100,以及如何检查1000或更大的数字

我试着将int输入转换成list,并用2位数字进行检查

no=int(input())
lis=[]
num_lis=[]
le=0

for i in range(10,no):
    lis=str(i)
    num_lis=[int (x)for x in lis]
    le=len(num_lis)-1
    if num_lis[le]>num_lis[le-1]:
        print(i)

从1到100没问题,如果打印正确,我想检查三个数字,如1<;2<;3 我的代码只检查最后两位我怎么检查三位和四位


Tags: noinltleforinputlenif
2条回答

打印所有低于后面数字的数字:

你只需记住一个数字,如果下一个数字更大,就可以打印出来:

number = None

while number is None:
    number = int(input("Input a number: ")) 
number = str(number)

last_digit = int(number[0])
for s in number[1:]:
    this_digit = int(s)
    if this_digit > last_digit:
        print(last_digit, end="")
        last_digit = this_digit
print(last_digit)

12354的输出:

1235

打印所有比下一个低的数字。你知道吗


检查数字是否“按升序”:

要检查,可以使用^{}。字符'0123456789'按以下顺序比较:'0'<'1'<'2'<'3'<'4'<'5'<'6'<'7'<'8'<'9'-无需将其转换为整数,只需按“原样”比较字符即可:

def IsIncreasing(number):
    n = str(number)
    return all(a<b for a,b in zip(n,n[1:]))

这是怎么工作的?
它使元组从数字和数字移1:

"123456789" 
"23456789" 
==> ('1','2'),('2','3'),...,('7','8'),('8','9') as generator of tuples

并使用^{}确保所有第一个元素都小于第二个元素

示例:

for k in [1234,1,123456798]:
    print(k,IsIncreasing(k))

输出(重新格式化):

1234      True
1         True
123456798 False

不需要通过需要更多计算的排序进行比较。你知道吗


测试从1到1000的所有数字:

您可以使用IsIncreasing()函数创建从1到1000的所有“递增”数字的列表:

get_all_up_to_1000 = [k for k in range(1,1001) if IsIncreasing(k)]

print( *(f"{k:>3}," for k in get_all_up_to_1000))

输出:

  1,   2,   3,   4,   5,   6,   7,   8,   9,  12,  13,  14,  15,  
 16,  17,  18,  19,  23,  24,  25,  26,  27,  28,  29,  34,  35,  
 36,  37,  38,  39,  45,  46,  47,  48,  49,  56,  57,  58,  59,  
 67,  68,  69,  78,  79,  89, 123, 124, 125, 126, 127, 128, 129, 
134, 135, 136, 137, 138, 139, 145, 146, 147, 148, 149, 156, 157, 
158, 159, 167, 168, 169, 178, 179, 189, 234, 235, 236, 237, 238, 
239, 245, 246, 247, 248, 249, 256, 257, 258, 259, 267, 268, 269, 
278, 279, 289, 345, 346, 347, 348, 349, 356, 357, 358, 359, 367, 
368, 369, 378, 379, 389, 456, 457, 458, 459, 467, 468, 469, 478, 
479, 489, 567, 568, 569, 578, 579, 589, 678, 679, 689, 789,

您可以创建一个函数来验证数字的位数是否已排序:

def int_sorted(i):
    s = str(i)
    return s == ''.join(sorted(s, key=int))

print(int_sorted(123))
print(int_sorted(1234))
print(int_sorted(4234))

输出

True
True
False

注意,sorted(s, key=int)使用sortedkey参数,根据每个数字的int值对s(数字字符串)进行排序。此函数的工作与位数无关。你知道吗

如果必须大于严格值,您可以:

def int_sorted(i):
    s = str(i)
    sorted_s = sorted(s, key=int)
    return s == ''.join(sorted_s) and all(int(c) < int(n) for c, n in zip(sorted_s, sorted_s[1:]))

print(int_sorted(123))
print(int_sorted(1234))
print(int_sorted(4234))
print(int_sorted(99))

输出

True
True
False
False

相关问题 更多 >