Python生成随机不重复数组

概述

生成指定范围内长度为n的数组.
参考 洗牌算法
世界上有哪些代码量很少,但很牛逼很经典的算法或项目案例? - 程序员吴师兄的回答 - 知乎

其实标准库random.shuffle也有实现.

Python

def get_random_list(start,stop,n):
    '''
    生成范围在[start,stop], 长度为n的数组.
    区间包含左右endpoint
    '''
    arr = list(range(start, stop+1))
    shuffle_n(arr,n)
    return arr[-n:]

def shuffle_n(arr,n):

    random.seed(time.time())
    for i in range(len(arr)-1,len(arr)-n-1,-1):
        print(i)
        j = random.randint(0,i)
        arr[i], arr[j] = arr[j], arr[i]

使用:

# 生成范围从0,100, 长度为10的数组
lst = get_random_list(0,100,10) 
[37, 57, 96, 90, 8, 13, 85, 71, 28, 30]
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值