今日头条测试开发的编程面试题---生成随机数

题目:程序中使用的数字只能是0和1,生成0-1000的随机数

算法描述:

如果生成的十进制数大于1000,则算法重新开始生成新的随机数,直到得到一个在0到1000范围内的数为止。

  1. 生成二进制数:

    • 算法开始时,会创建一个空的字符串 binary_string 用于存储二进制数。

    • 在一个循环中,算法会随机生成0或1,然后将生成的数字添加到 binary_string 的末尾,这个过程会重复10次,生成一个10位的二进制数。

  2. 转换为十进制数:

    • 生成完10位的二进制数后,算法会使用Python的内置函数 int(binary_string, 2) 将这个二进制数转换为对应的十进制数。

  3.  检查范围:

    • 如果生成的十进制数小于等于1000,则该数满足要求,算法返回这个数作为随机数。

这个算法的关键点在于它利用了二进制数的特性,通过随机生成一串0和1,然后将其转换为十进制数,以获得一个随机数。由于二进制数有固定的位数,因此我们可以确保生成的随机数的范围是均匀分布在0到1023(不包括1024)之间的整数。最后,通过检查是否在指定范围内,保证了生成的随机数在0到1000范围内。

代码如下:

  1. import random

  2. def generate_random_number():

  3. while True:

  4. # 初始化一个空字符串,用于存储生成的二进制数

  5. binary_string = ''

  6. loop_times = int(str(1)+str(0))#生成数字10,用于生成10位长度的二进制数字

  7. # 随机生成10位二进制数

  8. for i in range(loop_times):

  9. bit = random.randint(0, 1)

  10. binary_string += str(bit)

  11. base_num = 1+1 #生成数字2,在下行代码中使用2进制把binary_string转换为十进制

  12. # 将二进制字符串转换为十进制数

  13. decimal_number = int(binary_string, base_num)

  14. # 如果生成的数字在0到1000范围内,则返回

  15. if decimal_number <= 1000:

  16. return decimal_number

  17. # 测试生成的随机数

  18. random_number = generate_random_number()

  19. print("Generated random number:", random_number)

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值