Eurodiffusion

/***********并未完全AC***********/
#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
int c;//国家数目(即货币数目)
int cas=0;//测试组数
const int motif=1000000;
struct CTR{//存国家信息
string name;//名称
int x1,y1,xh,yh;//国家所在矩形的左下角和右上角
bool fi;//是否完成
int ft;//完成时间
bool operator <(const CTR& ci)const{
return ft<ci.ft||(ft==ci.ft&&name<ci.name);}
};
CTR ctr[25];
struct CTY{//存城市信息
int rest[25],get[25];//rest[i]表示第i种货币余额,get[i]表示从其他城市得到的数量
bool fi;//是否完成
bool exist;//是否为可用的城市
int belong;//属于哪个国家
};
CTY cty[25][25];//cty[x][y]表示点(x,y)上的城市
const int nextx[][2]={{1,0},{-1,0},{0,-1},{0,1}};//枚举四周的点
//这里写成next以后命名冲突了
void Init()//初始化
{
memset(cty,0,sizeof(cty));
printf("Case Number %d\n",++cas);
for(int i=0;i<c;i++)
{
CTR& con=ctr[i];
cin>>con.name>>con.x1>>con.y1>>con.xh>>con.yh;
//scanf("%s%d%d%d%d",con.name,&con.x1,&con.y1,&con.xh,&con.yh);
con.fi=0;con.ft=-1;
for(int j=con.x1;j<=con.xh;j++)
for(int k=con.y1;k<=con.yh;k++)
{
CTY& cit=cty[j][k];
cit.exist=1;cit.fi=0;cit.rest[i]=motif;cit.belong=i;
}
}
}
void inflow(int x,int y)//货币流入
{
CTY& cit=cty[x][y];
if(!cit.exist) return;//当前城市不合法
//int cnt=0;
for(int i=0;i<c;i++)
{
cit.rest[i]+=cit.get[i];
cit.get[i]=0;
}
for(int i=0;i<c;i++)
if(cit.rest[i]<1)//货币库存不足1
{
cit.fi=0;
return;
}
cit.fi=1;
return;
}
void outflow(int x,int y)
{
CTY& cit=cty[x][y];
if(!cit.exist) return;//不合法
int cnt=0;//周边城市个数
for(int i=0;i<4;i++)
{
int nx=x+nextx[i][0];
int ny=y+nextx[i][1];
if(cty[nx][ny].exist)cnt++;
}
if(!cnt)return;//周边没有城市
for(int i=0;i<c;i++)
{
int f=cit.rest[i]/1000;//要流出到每个城市的硬币
cit.rest[i]-=cnt*f;//i种货币减少
for(int j=0;j<4;j++)
{
int nx=x+nextx[j][0];
int ny=y+nextx[j][1];
if(cty[nx][ny].exist) cty[nx][ny].get[i]+=f;//i种货币流入
}
}
}
bool solve(int time)//模拟货币流通
{
bool solved=1;//标记是否全部完成
for(int i=0;i<c;i++)
{
int flag=0;
CTR& con=ctr[i];
for(int j=con.x1;j<=con.xh;j++)
for(int k=con.y1;k<=con.yh;k++)
inflow(j,k);//模拟货币流入
for(int j=con.x1;j<=con.xh;j++)
for(int k=con.y1;k<=con.yh;k++)
if(!cty[j][k].fi)
{
con.fi=0;flag=1;break;
}
if(!flag) con.fi=1;
if(!con.fi) solved=0;//有国家未完成
else if(con.ft==-1) con.ft=time;//避免重复更新
}
if(solved) return 1;//time时已经完成
for(int i=0;i<c;i++)
{
CTR& con=ctr[i];
for(int j=con.x1;j<=con.xh;j++)
for(int k=con.y1;k<=con.yh;k++)
outflow(j,k);//模拟货币流出
}
return 0;
}
int main()
{
while(cin>>c&&c)
{
Init();
int time=0;
for(;;)
if(solve(time++)) break;
sort(ctr,ctr+c);
for(int i=0;i<c;i++)
cout<<" "<<ctr[i].name<<" "<<ctr[i].ft<<endl;
//printf(" %s %d\n",ctr[i].name,ctr[i].ft);
}
return 0;
}

算法训练 Eurodiffusion的更多相关文章

  1. 蓝桥杯 算法训练 Torry的困惑(基本型)(水题,筛法求素数)

    算法训练 Torry的困惑(基本型) 时间限制:1.0s   内存限制:512.0MB      问题描述 Torry从小喜爱数学.一天,老师告诉他,像2.3.5.7……这样的数叫做质数.Torry突 ...

  2. 蓝桥杯 算法训练 区间k大数查询(水题)

    算法训练 区间k大数查询 时间限制:1.0s   内存限制:256.0MB 问题描述 给定一个序列,每次询问序列中第l个数到第r个数中第K大的数是哪个. 输入格式 第一行包含一个数n,表示序列长度. ...

  3. 算法训练 Hankson的趣味题

    算法训练 Hankson的趣味题   时间限制:1.0s   内存限制:64.0MB        问题描述 Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Han ...

  4. 算法训练 A+B Problem

     算法训练 A+B Problem   时间限制:1.0s   内存限制:512.0MB      问题描述 输入A,B. 输出A+B. 输入格式 输入包含两个整数A,B,用一个空格分隔. 输出格式 ...

  5. 算法训练 Hanoi问题

      算法训练 Hanoi问题   时间限制:1.0s   内存限制:512.0MB      问题描述 如果将课本上的Hanoi塔问题稍做修改:仍然是给定N只盘子,3根柱子,但是允许每次最多移动相邻的 ...

  6. 算法训练 区间k大数查询

    http://lx.lanqiao.org/problem.page?gpid=T11 算法训练 区间k大数查询   时间限制:1.0s   内存限制:256.0MB        问题描述 给定一个 ...

  7. 算法训练 Torry的困惑(基本型)

    http://lx.lanqiao.org/problem.page?gpid=T129 算法训练 Torry的困惑(基本型)   时间限制:1.0s   内存限制:512.0MB      问题描述 ...

  8. 算法训练 Anagrams问题

    http://lx.lanqiao.org/problem.page?gpid=T223 算法训练 Anagrams问题   时间限制:1.0s   内存限制:512.0MB      问题描述 An ...

  9. 蓝桥杯--算法训练 区间k大数查询

                                                                                 算法训练 区间k大数查询   时间限制:1.0 ...

随机推荐

  1. PHP的Undefined variable错误怎么解决?

    在调试程序时,有可能会出现Undefined variable错误,一般情况下php是不需要定义变量的,但如果服务器什么都报错的,就会出现错误,我们经常接收表单POST过来的数据时报Undefined ...

  2. 如何 求Ifeature 的面积

    IArea pArea = pfteature_Source.Shape as IArea;//  IArea来自geometry double dArea = Math.Round(pArea.Ar ...

  3. win8.1x64下完美运行IE6

    IE6我相信是所有前端人员永远都绕不过去的坎,操作的版本越来越高,离xp越来越远,难道你还在win8下安装个虚拟机来运行IE6吗?这样即消耗系统资源,来回的切换也麻烦,关键是只为了一个测试哦,没必要这 ...

  4. Spring cloud Eureka 服务治理(搭建服务注册中心)

    服务之类是微服务架构中最为核心的基础模块,它主要用来实现各个微服务实例的自动化注册和发现. 1. 服务注册 在服务治理框架中,通常会构建一个注册中心,每个服务单元向注册中心登记自己提供的服务,将主机. ...

  5. OpenFirewall

    1.写一份json文件:将要添加防火墙例外的应用程序和端口写入到json文件中 2.打开防火墙,读取json文件添加例外 /// <summary> /// Firewall.xaml 的 ...

  6. python3.7 安装 xlrd 模块---Mac

    要用Excel将数据和代码分离,需要import xlrd, 使用前需要先安装xlrd模块. 说明:通过在google中搜索“xlrd Mac”,下载xlrd.py模块(下载地址:http://mac ...

  7. 解决mysql连接输入密码提示Warning: Using a password on the command line interface can be insecure

    有时候客户端连接mysql需要指定密码时(如用zabbix监控mysql)5.6后数据库会给出个警告信息 mysql -uroot -pxxxx Warning: Using a password o ...

  8. C++ vector常用法

    在c++中,vector是一个十分有用的容器,下面对这个容器做一下总结. 1 基本操作 (1)头文件#include<vector>. (2)创建vector对象,vector<in ...

  9. IOS 当一个控件被添加到父控件中会调用(didMoveToSuperview)

    /** * 当一个控件被添加到父控件中就会调用 */ - (void)didMoveToSuperview { if (self.group.opened) { self.nameView.image ...

  10. 2018.5.30 Oracle数据库PLSQL编程---游标的使用

    显示游标的步骤 /* 显示游标处理步骤 1.声明游标 语法结构:cursor 游标名称 is SQL 语句; 2.打开游标 语法结构:open游标名称; 3.提取数据 语法结构:fetch 4.关闭游 ...