疫情模拟1.2

部署运行你感兴趣的模型镜像

更新:添加了运行后保存这一特点。
注:需将其提前放在一个文件夹里,还需新建一个文本文档,叫做a.txt。
IO:

def printtxt(name):
    f = open(name,"r",encoding="utf-8")
    print(f.read())
    f.close()

def writestr(str,name):
    with open(name,"w",encoding='utf-8') as f:
        f.write(str)

def writestr2(str,name):
    with open(name,"a",encoding='utf-8') as f:
        f.write(str)

def writelist(list,name):
    for j in range(len(list)-1):
        writestr2(str(list[j])+" ",name)
    writestr2(str(list[len(list)-1])+".",name)

def write2dlist(list,name):
    for i in range(len(list)-1):
        writelist(list[i],name)
        writestr2("\n",name)
    writelist("-",name)
    writestr2("\n",name)



main:

from listturtle import *
import turtle
from 疫情 import *
from IO import *


list1=[]
list1=createlist(10)
list1=createpeople(list1,10)
list1=listrandom(list1)
writestr("","a.txt")

for i in range(5):
    list1=refresh2(list1,100,14,2)
    list1=refresh(list1)
    printlist(list1)
    write2dlist(list1,"a.txt")
    draw2dlist(list1,20,-200,200)
    turtle.reset()
draw2dlist(list1,20,-200,200)

writestr2("/","a.txt")



listturtle:

import turtle
import time


def point(a):
    turtle.speed(0)
    turtle.pensize(3)
    turtle.pencolor(a)
    turtle.hideturtle()
    turtle.circle(1)

def drawpoint(x,y,a):
    turtle.penup()
    turtle.goto(x,y)
    turtle.pendown()
    point(a)

def drawlist(list,bc,y,x):
    turtle.pendown()
    for i in range(len(list)):
        if list[i]==1:
            drawpoint(x,y,"blue")
        elif list[i]==2:
            drawpoint(x,y,"red")
        elif list[i]>2:
            drawpoint(x,y,"orange")
        x+=bc

def draw2dlist(list,bc,x,y):
    for i in range(len(list)):
        drawlist(list[i],bc,y,x)
        y-=bc
        turtle.penup()
        turtle.goto(x,y)
    time.sleep(1)



疫情:

import random


def createlist(c):
    a=[]
    b=[]
    for i in range(c):
        b=[]
        for j in range(c):
            b.append(0)
        a.append(b)
    return a

def printlist(a):
    for i in range(len(a)):
        print(a[i])
    print()

def createpeople(list,people):
    for i in range(len(list)):
        for j in range(people):
            list[i][j]=1
    list[0][0]=2
    list[0][1]=0
    return list

def listrandom(list):
    for i in range(len(list)):
        for i in range(len(list[i])):
            random.shuffle(list[i])
        random.shuffle(list)
    return list

def goto(list,x,y,a):
    if list[y][x]!=0:
        if a==1:
            if y-1>=0 and list[y-1][x]==0:
                list[y-1][x]=list[y][x]
                list[y][x]=0
        if a==2:
            if y+1<len(list) and list[y+1][x]==0:
                list[y+1][x]=list[y][x]
                list[y][x]=0    
        if a==3:
            if x-1>=0 and list[y][x-1]==0:
                list[y][x-1]=list[y][x]
                list[y][x]=0
        if a==4:
            if x+1<len(list[y]) and list[y][x+1]==0:
                list[y][x+1]=list[y][x]
                list[y][x]=0

    return list

def refresh(list):
    for i in range(len(list)):
        for j in range(len(list[i])):
            if list[i][j]!=0 and list[i][j]<=2:
                list=goto(list,j,i,random.randint(1,4))
            if list[i][j]>2:
                list[i][j]=list[i][j]-1
                list=goto(list,j,i,random.randint(1,4))
    return list

def disease(list,a,x,y,q):
    if list[y][x]==1:
        if y+1<len(list) and list[y+1][x]>=2:
            b=random.randint(1,100)
            if b<=a:
                list[y][x]=q
                
        if y-1>-1 and list[y-1][x]>=2:
            b=random.randint(1,100)
            if b<=a:
                list[y][x]=q
                
        if y+1<len(list) and x+1<len(list[0]) and list[y+1][x+1]>=2:
            b=random.randint(1,100)
            if b<=a:
                list[y][x]=q
                
        if y+1<len(list) and x-1>-1 and list[y+1][x-1]>=2:
            b=random.randint(1,100)
            if b<=a:
                list[y][x]=q

        if y>-1 and x+1<len(list[0]) and list[y-1][x+1]>=2:
            b=random.randint(1,100)
            if b<=a:
                list[y][x]=q

        if y-1>-1 and x-1>-1 and list[y-1][x-1]>=2:
            b=random.randint(1,100)
            if b<=a:
                list[y][x]=q
    return list

def refresh2(list,s,q,z):
    for i in range(len(list)):
        for j in range(len(list[i])):
            b=random.randint(1,100)
            if list[i][j]==1:
                list=disease(list,s,i,j,q)
            if list[i][j]==2:
                if b<=z:
                    list[i][j]=0
    return list


想要提供帮助请到github
想要提出意见请到力扣
想要查看更多文章请到文章集合
下次更新:

  • 文件模拟出此程序效果
  • 感染者可能被治愈
  • 显示出有几个潜伏期患者,几个发病患者

您可能感兴趣的与本文相关的镜像

Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

``` {—————————————— 优化后系统参数 ——————————————} {——动态估值体系——} IND_PETTM:=FINANCE(33)/FINANCE(1); DYNPETTM_NORM:=CLOSE/(IND_PETTM*0.7 + MA(IND_PETTM,240)*0.3); PB_RATE:=CLOSE/MAX(FINANCE(5),0.000000001); {修正点} PEG_VAL:=DYNPETTM_NORM/MAX((FINANCE(54)/MA(FINANCE(34),3))*100,0.000000001); {修正点} {——智能波动率——} VOL_BAND:=EMA(STD(CLOSE,IF(VOL>MA(VOL,20)*2,10,30)),20); ADAPTIVE_VOL:=STD(CLOSE,20)/MA(CLOSE,20)*0.6 + VOL_BAND*0.4; VAR_PERIOD:=FLOOR(60-200*ADAPTIVE_VOL); MACD_PERIOD:=CEILING(60 - 40*ADAPTIVE_VOL); {——情绪引擎——} MF_RATIO:=SUM(IF(CLOSE>DYNAINFO(11),VOL,-VOL),5)/MA(VOL,5); HOT_INDEX_NEW:=EMA(MF_RATIO*0.5 + (AMOUNT/INDEXAMOUNT)*0.5,3); MONEY_FLOW:=EMA((AMOUNT-REF(AMOUNT,1))/REF(AMOUNT,1),3); SENTI_ACCEL:=MF_RATIO*HOT_INDEX_NEW/(1+ABS(MONEY_FLOW)); {——多周期共振——} MONTH_EMA_PERIOD:=IF(SLOPE(INDEXC,60)>0,360,480); MONTH_MA_NEW:=EMA(CLOSE,MONTH_EMA_PERIOD); MONTH_TREND:=CLOSE>MONTH_MA_NEW*1.02 AND SLOPE(MONTH_MA_NEW,5)>0; WEEK_DIF:=EMA(CLOSE,MACD_PERIOD)-EMA(CLOSE,MACD_PERIOD*2.2); WEEK_DEA:=EMA(WEEK_DIF,MACD_PERIOD*0.618); WEEK_MACD:=2*(WEEK_DIF-WEEK_DEA); WEEK_VOL:=EMA(V,5)>EMA(V,21)*1.2 AND V>REF(MA(V,5),1)*1.4; DAY_BREAK:=CLOSE>HHV(REF(HHV(HIGH,20),1),3) AND V>MA(V,20)*1.5; RSI6:=SMA(MAX(C-REF(C,1),0),6,1)/SMA(ABS(C-REF(C,1)),6,1)*100; DAY_RSI:=RSI6>65 AND RSI6<85; MIN60_BREAK:='CLOSE#MIN60'>'HHV(HIGH,15)#MIN60' AND 'VOL#MIN60'>'MA(VOL,20)#MIN60'*1.8; {——信号合成——} IND_CAPITAL:=EMA(SUM(AMOUNT,5)/FINANCE(1),3); INDUSTRY_RANK:=RANK(IND_CAPITAL)*0.6 + RANK(C/REF(C,20)/(INDEXC/REF(INDEXC,20)))*0.4; VOL_FILTER:=ADAPTIVE_VOL BETWEEN 0.15 AND 0.85; DEBT_FILTER:=FINANCE(42)/FINANCE(1)<0.45; CASH_FLOW:=FINANCE(25)/FINANCE(1)>0.25; FINAL_SIGNAL:MONTH_TREND AND INDUSTRY_RANK>0.75 AND WEEK_MACD>REF(WEEK_MACD,1) AND WEEK_VOL AND DAY_BREAK AND DAY_RSI AND MIN60_BREAK AND DEBT_FILTER AND CASH_FLOW AND PEG_VAL<0.75 AND DYNPETTM_NORM<22 AND SENTI_ACCEL>1.5 AND HOT_INDEX_NEW>1.2 AND MONEY_FLOW>0.12 AND VOL_FILTER;```你的身份是高级编程技术专家,精通各类编程语言,能对编程过程中的各类问题进行分析和解答。我的问题是【我编辑通达信选股代码,你如何深度理解此代码能否选到资金持续流入,股票市场情绪启动,盘中异动启动主升浪的股票,及日线盘中预警选股和盘后选股。用2018-2024年全A股周期回测验证此代码选股逻辑的准确性和胜率,评估月胜率达到多少?评估有效信号准确率达到多少?
03-29
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值