文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

番外篇:分享一道用Python基础+蒙特卡洛算法实现排列组合的题目(附源码)

2024-12-02 17:36

关注

大家好,我是Python进阶者。

是不是觉得很诧异?明明上周刚发布了这篇:分享一道用Python基础+蒙特卡洛算法实现排列组合的题目(附源码),今天又来一篇,名曰番外篇!其实今天是想给大家分享【🌑(这是月亮的背面)】大佬的解法,拍案叫绝!

前情回顾

前几天在才哥交流群里,有个叫【Rick Xiang】的粉丝在Python交流群里问了一道关于排列组合的问题,初步一看觉得很简单,实际上确实是有难度的。

题目是:一个列表中有随机15个数,没有重复值。从列表里面任意选5个数,如何选出来包含a, a+1的所有组合。a可以是15个数中的任意一个。

关于思路和解决方法,这篇文章分享一道用Python基础+蒙特卡洛算法实现排列组合的题目(附源码)中提供了【张老师】和【有点意思】大佬的想法和解决方案,一共有5份代码,足够大家学习了,感兴趣的小伙伴快去学习吧,干货满满。

二、新代码

上周五的时候,发布了这篇分享一道用Python基础+蒙特卡洛算法实现排列组合的题目(附源码)原创文章,很庆幸还有粉丝亲自实践,并给出了建设性的方案,如下图所示。

这里先给出【🌑(这是月亮的背面)】大佬的伪代码,这样看上去大家也更加好理解一些。

  1. # -*- coding: utf-8 -*- 
  2. # 模块化 
  3. import random 
  4. import numpy as np 
  5. import time 
  6.  
  7.  
  8. # 取出随机的15个数值 
  9. def get_random15(): 
  10.     random_array = [np.array(random.sample(range(2000), 15)) for i in range(100000)] 
  11.     random5 = {get_random5(random15) for random15 in random_array} 
  12.     return [i for i in random5 if i] 
  13.  
  14.  
  15. # 遍历随机的15个数值,取相邻的两个随机数,判断后返回满足条件的值 
  16. def get_random5(random_15): 
  17.     random_5 = set(random_15[random.sample(range(15), 5)])  # np.array的索引替换choice取值 
  18.     # 利用set特性判断元素是否含有给定的元素 
  19.     random_5_resp = {True if len(random_5.intersection({num, num + 1})) == 2 else False for num in random_5} 
  20.     return tuple(random_5) if True in random_5_resp else () 
  21.  
  22.  
  23. if __name__ == '__main__'
  24.     start_time = time.time() 
  25.     final_result = get_random15() 
  26.     print("共%d个符合题意的列表" % len(final_result)) 
  27.     print("分别是:%s" % final_result) 
  28.     end_time = time.time() 
  29.     used_time = end_time - start_time 
  30.     print() 
  31.     print("本次程序用时:{}".format(time.strftime('%H(小时):%M(分钟):%S(秒)'time.gmtime(used_time)))) 

这个代码写的真的很好,没有Python基础的小伙伴看上去肯定有些吃力的,小编自己初看的时候,也觉得有点难以吸收,需要多看几遍,领悟。

这个代码亲测有效,用之前的代码大概需要12秒,改用这个只需要1.5秒。

他这里做了三个优化,其一是之前从15个数中随机取5个值耗时较长,这里用使用了numpy.array的特性来优化代码,在科学计算中,可以省掉很多循环语句,代码使用方面比Python列表简单,Python list 无法直接运算, Numpy Array 可直接运算;其二是删除了之前的去重函数,这里他也用set去优化,所以在这块也节约了时间;其三是使用了集合的交集运算(Intersection),较之前的if判断来说,节约了时间。

想到这里,不得不感叹一下,【人生苦短,我用python】!

三、总结

我是Python进阶者。本文基于粉丝针对排列组合问题的提问,给出了一个利用Python基础+蒙特卡洛算法的解决方案,基本上可以达到了粉丝的要求。

不过话说回来,这个方案虽是当下最优,但不是永远最优。

 

来源:Python爬虫与数据挖掘内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯