每次随机生成 1 个[-100, 100] 之间的整数,共生成 10 个整数加到列表中,使用 lambda 函数对列表元素进行排序,使输出结果为正数在前,从大到小排列,负数在后,从小到大排列。
提供三种方法,结果测试一样:
import random
n = int(input())
random.seed(n)
lst = [random.randint(-100,100) for _ in range(10)]
# 可以用 lst = random.choices(range(-100,101), k=10),但输出随机数不同
lst = sorted(lst, key=lambda x:x if x>=0 else 1/x, reverse=True) # 把负数取倒数实现反序
print(lst)
# 或者升序,但x 1/x取负值一样也降序
random.seed(n)
lst = [random.randint(-100,100) for _ in range(10)]
lst = sorted(lst, key=lambda x:-x if x>=0 else -1/x)
print(lst)
# 或分两段分别排序
random.seed(10)
lst = [random.randint(-100,100) for _ in range(10)]
lst = list(sorted(filter(lambda x:x>=0,lst),reverse=True))+list(sorted(filter(lambda x:x<0,lst)))
print(lst)