算法训练 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的更多相关文章
- 蓝桥杯 算法训练 Torry的困惑(基本型)(水题,筛法求素数)
算法训练 Torry的困惑(基本型) 时间限制:1.0s 内存限制:512.0MB 问题描述 Torry从小喜爱数学.一天,老师告诉他,像2.3.5.7……这样的数叫做质数.Torry突 ...
- 蓝桥杯 算法训练 区间k大数查询(水题)
算法训练 区间k大数查询 时间限制:1.0s 内存限制:256.0MB 问题描述 给定一个序列,每次询问序列中第l个数到第r个数中第K大的数是哪个. 输入格式 第一行包含一个数n,表示序列长度. ...
- 算法训练 Hankson的趣味题
算法训练 Hankson的趣味题 时间限制:1.0s 内存限制:64.0MB 问题描述 Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Han ...
- 算法训练 A+B Problem
算法训练 A+B Problem 时间限制:1.0s 内存限制:512.0MB 问题描述 输入A,B. 输出A+B. 输入格式 输入包含两个整数A,B,用一个空格分隔. 输出格式 ...
- 算法训练 Hanoi问题
算法训练 Hanoi问题 时间限制:1.0s 内存限制:512.0MB 问题描述 如果将课本上的Hanoi塔问题稍做修改:仍然是给定N只盘子,3根柱子,但是允许每次最多移动相邻的 ...
- 算法训练 区间k大数查询
http://lx.lanqiao.org/problem.page?gpid=T11 算法训练 区间k大数查询 时间限制:1.0s 内存限制:256.0MB 问题描述 给定一个 ...
- 算法训练 Torry的困惑(基本型)
http://lx.lanqiao.org/problem.page?gpid=T129 算法训练 Torry的困惑(基本型) 时间限制:1.0s 内存限制:512.0MB 问题描述 ...
- 算法训练 Anagrams问题
http://lx.lanqiao.org/problem.page?gpid=T223 算法训练 Anagrams问题 时间限制:1.0s 内存限制:512.0MB 问题描述 An ...
- 蓝桥杯--算法训练 区间k大数查询
算法训练 区间k大数查询 时间限制:1.0 ...
随机推荐
- P1736 创意吃鱼法80
题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...
- Java 编码规范有感
应小组要求,开发测试都需要考阿里编码规范,因此,相当于是突击了一下关于编码规范方面的知识,目前做的项目后期需要进行项目迁移,数据迁移,功能迁移... 各种迁移... 阿里巴巴编码规范(Java)考试地 ...
- hibernate课程 初探单表映射1-8 hibernate持久化类
java beans 的设计原则 1 公有的类 2 共有不带参数构造方法 3 私有属性 4 属性setter/getter方法 Studnet类: package com.ddwei.student; ...
- Oracle 11g服务详细介绍
按照windows 7 64位 安装oracle 11g R2中的方法成功安装Oracle 11g后,共有7个服务,这七个服务的含义分别为: 1. Oracle ORCL VSS Writer Ser ...
- mui的ajax例子3
mui.get() 前端页面: <!DOCTYPE html><html><head> <meta charset="utf-8"> ...
- windows 下设置MTU数值
输入:netsh interface ipv4 show subinterfaces 查询到目前系统的MTU值.再分别输入一行按一次回车键. netsh interface ipv4 set subi ...
- 高德地图 获取sha1
开发版本sha1 控制台输入 cd .android 回车 再输入 keytool -list -v -keystore debug.keystore 回车 输入密钥库口令: andorid ...
- Centos内核调优参考
net.ipv4.tcp_syn_retries = 1 net.ipv4.tcp_synack_retries = 1 net.ipv4.tcp_keepalive_time = 600 net.i ...
- hdu-2066 一个人的旅行---模板题
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2066 题目大意: 求到目标点集合中的最短距离 解题思路: dijkstra算法求出每个点到该点的最短 ...
- [OS] 可执行文件的装载
http://www.jianshu.com/p/e1300e7a4c48 1. 虚拟内存 在早期的计算机中,程序是直接运行在物理内存上的,程序在运行时访问的地址就是物理地址.可是,当计算机中同时运行 ...