事情发生背景:

  题目是:有10万个随机数,请写一段代码,找出前10个最小的。

  一开始我想的是直接用python语法糖(列表生成式)生成一个随机的10万个数字。

  但是我发现以我目前的能力完成不了,因此我就用了一个列表和一个列表生成式做出了一个伪随机数.

  import random
  import heapq
  list1 = []
  for a in range(20,2000000):
list1.append(a)
  list2 = []
  for i in range(10000):
  list2.append(random.choice(list1))
  res = heapq.nsmallest(10, list2)
  print(res)

事情经过:
  问题这样也就解决了(虽然是不完美的解决),但是我觉得不够简洁,基于PythonIC(该名词上面有详细介绍)的严谨,就想到直接列表生成式做出伪随机数。
  于是就有了这样(自认为的)怪诞。。。
   
  
  import random
  list1 = []
  list2 = []
  #双层伪随机数造成伪最终的随机数
  list1 = [list1.append(random.randint(1,2000000))for i in range(1,20000)]
  print(list1)
  list2 = [list2.append(random.choice(list1))for i in range(20)]
  print(list2)

 

 

 

 

 为什么会是None类型呢???的目前我无法理解的事情,记录下来,等待以后自己有足够的知识背景再来解释,大家有什么想法也可以讨论下。

版权声明:本文为yp19970原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/yp19970/p/11956720.html