各位朋友们,小编在这里要分享,python简单的病毒编程代码 如何用python做恶搞病毒,一起探索吧!
大家好,本文将围绕python简单的病毒编程代码展开说明,如何用python做恶搞病毒是一个很多人都想弄明白的事情,想搞清楚python病毒传播模型需要先了解以下几个事情python编辑器手机版怎么用,好用的手机python编辑器。
Source code download: 本文相关源码
文章目录
概述方法1. 面向对象方式 1. 导入包2. 全局参数3. 定义人4. 环境5. 病毒感染6. 动态显示7. 结果方法2. 矩阵运算方式 1. 代码2. 重难点3. 单点到多点的距离4. 结果
概述
本章借助matplotlib
包,模拟疫情传播,有两种思路:
使用面向对象的方式,每个人为一个独立对象使用矩阵的方式
方法1. 面向对象方式
面向对象的方式,每个人为一个独立对象,算法:
遍历所有对象: 更新当前对象位置(移动)计算当前对象到其他所有人的相对距离根据距离,感染率等因素,改变对象邻居当前的状态。
算法逻辑非常简单,但是可以看到会嵌套多次循环,时间复杂度为: O ( n 2 ) O(n^2) O(n2)
1. 导入包
import numpy as np
import matplotlib.pyplot as plt
2. 全局参数
# 地图宽度
width = 100
# 总人口
pop = 2000
# 初始病人数量
n = 10
# 感染半径
sd = 10
# 感染几率 50%
sr = 0.5
3. 定义人
坐标:随机分布颜色:绿色代表健康,红色代表感染运动函数:人随机运动
# 人
class People(object):
def __init__(self):
# 随机坐标
self.x = () * width
self.y = () * width
= np.array([self.x, self.y])
self.color = 'g'
# 随机运动
def move(self):
self.x += n()
self.y += n()
4. 环境
按照人口生成不同的人口对象随机选择病源
# 人群
all_people = np.array([People() for i in range(pop)])
# 初始化患病人群
sick_people = np.random.choice(all_people, size=n, replace=False)
for p in sick_people:
p.color = "r"
5. 病毒感染
遍历所有人群,区分患者与普通人遍历患者: 遍历所有人,计算与当前患者的距离 当目标与患者距离小于传播半径,则有一定几率感染python自学能行吗。返回患病熟料
# 病毒感染函数
def affect(all_people):
sick_people = []
healthy_people = []
n = 0
for p in all_people:
if p.color == "r":
sick_people.append(p)
n += 1
原文地址1:https://blog.csdn.net/2401_83157073/article/details/136339725
参考资料:python中用turtle画一个圆形 https://blog.csdn.net/SXIAOYAN_/article/details/140061099