编程c++模拟疫情游戏

本文介绍如何使用C++编程语言模拟疫情游戏。在疫情时期,作者通过编写代码来阐述实现过程。
摘要由CSDN通过智能技术生成

**

编程c++模拟疫情游戏

疫情期,写代码,我写你不写
下面直接附代码

#include<stdio.h>
#include<windows.h>
#include<time.h> 
#include<bits/stdc++.h>
using namespace std;

int somepeople=2000,chuangwei=200,shtime=7,viruspropagation=40,treatment=93,deadment=100,virusspreadingfar=1;
int immunizetime=160;
double carefully=0.33,runpeople=0.221;
/*
    新冠 2000,200,7,65,5,6,2,180,0.66 
   SARS 2000,200,7,60,93,100,1,120,0.66
  流感 2000,200,3,40,99,100,1,160,0.33*/
int illpeople=0,zhiyupeople=0,deadpeople=0;


struct people{
   
	int x,y;//x列 y行 
	int health_subhealth_ill;//health,subhealth(亚健康,即处在潜伏期(潜伏期也传染)),ill分别对应1,2,3;
	int forward;//上下左右 1,2,3,4
	int work;//步数 
	int subhealthtime,healthtime;
	int inhospital;//在,不在 1,0
	int dead;//死,活 1,0
	int firstill;//first,not 0,1
	int firstillture;//first,not 0,1
}whp[20000];

struct hospital{
   
	int x,y;
}whh[20000];

void gotoxy(int x,int y) 
{
   
	COORD  coord;
	coord.X=x;
	coord.Y=y;
	HANDLE a=GetStdHandle(STD_OUTPUT_HANDLE);
	SetConsoleCursorPosition(a,coord);
}

void ColorChoose(int color)   //颜色选择函数
{
   
	switch(color)
	{
   	
		case 1:               //天蓝色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_GREEN|FOREGROUND_BLUE);
		break;
		case 2:               //绿色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_GREEN);	
		break;
		case 3:               //黄色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_RED|FOREGROUND_GREEN);
		break;
		case 4:               //红色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_RED);
		break;
		case 5:               //紫色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_RED|FOREGROUND_BLUE);
		break;
		case 6:               //白色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_RED|FOREGROUND_BLUE|FOREGROUND_GREEN);
		break;
		case 7:               //深蓝色
		SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY|FOREGROUND_BLUE);
		break;
	}
}

void spreading(){
   
	for(int i=1;i<=somepeople;i++){
   
		if(whp[i].firstill==1){
   
			whp[i].healthtime+=1;
		}
		if(whp[i].healthtime==immunizetime&&whp[i].firstill==1){
   
			whp[i].healthtime=0;
			whp[i].firstill=0;
			gotoxy(whp[i].x,whp[i].y);
			ColorChoose(6);
			printf("#"); 
		}
	}
	for(int i=1;i<=somepeople;i++){
   
		if
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
疫情统计与预测系统 1.基本要求: [1]编写一个新冠肺炎疫情统计与预测系统,实现对不同国家不同城市的疫情情况的管理,并根据前若干天的新增病例数及现存病例,预测当天的新增病例数。 [2]城市疫情信息包括:国家名称、城市名称、疫情数据(新增病例数、现有病例数、累计病例数、治愈病例数、死亡病例)以及新增病例的预测结果,疫情预测模型的辨识以及疫情的预测通过成员函数实现。 2.基本管理功能: [1]城市添加:增加一个城市,并输入(或从文件中读入)这个城市的所属国家及疫情数据。 [2]国家(城市)修改:修改已经选择的国家(城市)。 [3]国家(城市)删除:删除已经选择的国家(城市)。 [4]疫情预测:预测已选城市的新增病例数。 [5]打印功能:以表格形式打印全部城市疫情信息。 [6]统计功能:所有城市疫情数据可以分别按照新增病例数、现有病例数、累计病例数、治愈病例数、死亡病例数从高到低排序并打印,并可通过选择不同国家来查看该国家的所有城市累计疫情数据 新增病例数、现有病例数、累计病例数、治愈病例数、死亡病例)。 [7]信息保存:将全部城市疫情信息保存到不同的文件中(数据库文件或普通文本文件)。 3.其他要求及说明: [1]要求系统至少包含3个国家,每个国家至少包含10个城市,每个城市至少保存30天的数据,疫情信息可以上网查,也可自己输入合理数据。 [2]当日新增病例数采用时间序列方法预测,即根据前面n天的平均新增病例数x1, x2, …, xn预测当天的新增病例数y,即采用如下的预测模型: y = a0 + a1·x1 + a2·x2 + … + an·xn 其中系数a0, a1, a2, …, an需要根据历史数据,编写算法求得(可采用最小二乘法)。模型中的参数n要求大于10,可以设为固定值,也可以由用户自己设定。 [3]鼓励大家自己采用其他的预测模型。 [4]鼓励大家设计更多的系统功能。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值