Codeforces Round #327 (Div. 1) C. Three States
5 seconds
512 megabytes
standard input
standard output
The famous global economic crisis is approaching rapidly, so the states of Berman, Berance and Bertaly formed an alliance and allowed the residents of all member states to freely pass through the territory of any of them. In addition, it was decided that a
road between the states should be built to guarantee so that one could any point of any country can be reached from any point of any other State.
Since roads are always expensive, the governments of the states of the newly formed alliance asked you to help them assess the costs. To do this, you have been issued a map that can be represented as a rectangle table consisting of n rows
and m columns. Any cell of the map either belongs to one of three states, or is an area where it is allowed to build a road, or is
an area where the construction of the road is not allowed. A cell is called passable, if it belongs to one of the states, or the road was built in this cell. From any passable cells you can move
up, down, right and left, if the cell that corresponds to the movement exists and is passable.
Your task is to construct a road inside a minimum number of cells, so that it would be possible to get from any cell of any state to any cell of any other state using only passable cells.
It is guaranteed that initially it is possible to reach any cell of any state from any cell of this state, moving only along its cells. It is also guaranteed that for any state there is at least one cell that belongs to it.
The first line of the input contains the dimensions of the map n and m (1 ≤ n, m ≤ 1000) —
the number of rows and columns respectively.
Each of the next n lines contain m characters,
describing the rows of the map. Digits from 1 to 3 represent
the accessory to the corresponding state. The character '.' corresponds to the cell where it is allowed to build a road and the character '#'
means no construction is allowed in this cell.
Print a single integer — the minimum number of cells you need to build a road inside in order to connect all the cells of all states. If such a goal is unachievable, print -1.
4 5
11..2
#..22
#.323
.#333
2
1 5
1#2#3
-1
题意:有三个国家,要建造一些桥,使得三个国家能相互连通,问最少要造多少桥。
思路:共有两种情况,一种是先使得两个国家连通,然后再使它们和另一个连通,还有一种是设一个点,造桥使得这三个国家都到这个点。
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
typedef long long ll;
#define inf 99999999
#define maxn 1005
char s[maxn][maxn];
int dist[maxn][maxn][4],vis[maxn][maxn]; //dsit[i][j][num]表示坐标为i,j的点到值为num所对的这个国家的最小要造的桥数
int st[4][2],n,m;
int ans[4][4]; //ans[i][j]表示i国家和j国家要连通所要造的桥的个数
int tab[4][2]={0,1,-1,0,0,-1,1,0};
int q[1111111][3];//0 x,1 y,2 t
void bfs(int num)
{
int i,j,x,y,t,xx,yy,tt;
int front,rear;
front=rear=1;
x=st[num][0];
y=st[num][1];
q[front][0]=x;
q[front][1]=y;
q[front][2]=0;
dist[x][y][num]=0;
vis[x][y]=1;
while(front<=rear){ //这里先把值为num的国家都找出来,这些都是连通的
x=q[front][0];
y=q[front][1];
t=q[front][2];
front++;
for(i=0;i<4;i++){
xx=x+tab[i][0];
yy=y+tab[i][1];
if(xx>=1 && xx<=n && yy>=1 && yy<=m && s[xx][yy]-'0'==num && !vis[xx][yy]){
vis[xx][yy]=1;
dist[xx][yy][num]=0;
rear++;
q[rear][0]=xx;
q[rear][1]=yy;
q[rear][2]=0;
}
}
}
front=1; //这里值为num的国家要再次放入队列
while(front<=rear){
x=q[front][0];
y=q[front][1];
t=q[front][2];
front++;
for(i=0;i<4;i++){
xx=x+tab[i][0];
yy=y+tab[i][1];
if(xx>=1 && xx<=n && yy>=1 && yy<=m && s[xx][yy]!='#' && !vis[xx][yy]){
vis[xx][yy]=1;
if(s[xx][yy]=='.'){
dist[xx][yy][num]=t+1;
rear++;
q[rear][0]=xx;
q[rear][1]=yy;
q[rear][2]=t+1;
}
else{
int cot=s[xx][yy]-'0';
dist[xx][yy][num]=t+1;
ans[num][cot]=min(ans[num][cot],t+1);
rear++;
q[rear][0]=xx;
q[rear][1]=yy;
q[rear][2]=t+1;
}
}
}
}
}
int main()
{
int i,j,ant;
while(scanf("%d%d",&n,&m)!=EOF)
{
for(i=1;i<=n;i++){
scanf("%s",s[i]+1);
for(j=1;j<=m;j++){
if(s[i][j]=='1'){
st[1][0]=i;st[1][1]=j;
}
if(s[i][j]=='2'){
st[2][0]=i;st[2][1]=j;
}
if(s[i][j]=='3'){
st[3][0]=i;st[3][1]=j;
}
dist[i][j][1]=dist[i][j][2]=dist[i][j][3]=inf;
}
}
for(i=1;i<=3;i++){
for(j=1;j<=3;j++){
if(i!=j){
ans[i][j]=inf;
}
else ans[i][j]=0;
}
}
for(i=1;i<=3;i++){
memset(vis,0,sizeof(vis));
bfs(i);
}
ant=inf;
ant=min(ant,ans[1][2]+ans[1][3]-2);
ant=min(ant,ans[2][1]+ans[2][3]-2);
ant=min(ant,ans[3][1]+ans[3][2]-2);
for(i=1;i<=n;i++){
for(j=1;j<=m;j++){
if(s[i][j]!='#'){
if(s[i][j]=='.'){
ant=min(ant,dist[i][j][1]+dist[i][j][2]+dist[i][j][3]-2);
}
else{
ant=min(ant,dist[i][j][1]+dist[i][j][2]+dist[i][j][3]-2);
}
}
}
}
if(ant>10000000)printf("-1\n");
else printf("%d\n",ant);
}
return 0;
}
Codeforces Round #327 (Div. 1) C. Three States的更多相关文章
- Codeforces Round #327 (Div. 2) E. Three States BFS
E. Three States Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/591/probl ...
- Codeforces Round #327 (Div. 2) E. Three States
题目链接: 题目 E. Three States time limit per test:5 seconds memory limit per test:512 megabytes 问题描述 The ...
- 暴搜 - Codeforces Round #327 (Div. 2) E. Three States
E. Three States Problem's Link Mean: 在一个N*M的方格内,有五种字符:'1','2','3','.','#'. 现在要你在'.'的地方修路,使得至少存在一个块'1 ...
- E. Three States - Codeforces Round #327 (Div. 2) 590C States(广搜)
题目大意:有一个M*N的矩阵,在这个矩阵里面有三个王国,编号分别是123,想知道这三个王国连接起来最少需要再修多少路. 分析:首先求出来每个王国到所有能够到达点至少需要修建多少路,然后枚举所有点求出来 ...
- Codeforces Round #327 (Div. 2) A. Wizards' Duel 水题
A. Wizards' Duel Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/591/prob ...
- Codeforces Round #327 (Div. 2) D. Chip 'n Dale Rescue Rangers 二分 物理
D. Chip 'n Dale Rescue Rangers Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/co ...
- Codeforces Round #327 (Div. 2) C. Median Smoothing 找规律
C. Median Smoothing Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/591/p ...
- Codeforces Round #327 (Div. 2) B. Rebranding 水题
B. Rebranding Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/591/problem ...
- Codeforces Round #327 (Div. 1), problem: (A) Median Smoothing
http://codeforces.com/problemset/problem/590/A: 在CF时没做出来,当时直接模拟,然后就超时喽. 题意是给你一个0 1串然后首位和末位固定不变,从第二项开 ...
随机推荐
- Java远程下载文件到本地(http协议和ssh2协议)
Java中java.io包为我们提供了输入流和输出流,对文件的读写基本上都依赖于这些封装好的关于流的类中来实现.前段时间遇到了以下两种需求: 1.与某系统对接,每天获取最新的图片并显示在前端页面.该系 ...
- 通过JS逆向ProtoBuf 反反爬思路分享
前言 本文意在记录,在爬虫过程中,我首次遇到Protobuf时的一系列问题和解决问题的思路. 文章编写遵循当时工作的思路,优点:非常详细,缺点:文字冗长,描述不准确 protobuf用在前后端传输,在 ...
- SAPLink 非常好用的工具
对于SAP LINK,如果你想将一个程序完整的保存到本地,包括程序的自定义屏幕.菜单等等,那么请使用这个工具,它能够将一个程序完整的保存下来,并且移植到另一个SAP系统中,用来左程序的迁移和本地保存备 ...
- CentOS 7 下安装 mysql ,以及用到的命令
VMware虚拟机装好后,再装个CentOS7系统,以上环境自行百度... 一.Linux下查看mysql是否安装 1.指令ps -ef|grep mysql [root@localhost 桌面]# ...
- Android N wifi auto connect流程分析
定义 当有两个或者两个以上的已经保存的无线网络可以连接时,系统通过选择算法来选择一个最优网络. 在Android L,wifi的自动重连机制是由WifiAutoJoinController 类来实现, ...
- jQuery 真伪数组的转换
//真数组转换伪数组 var arr = [1,3,5,7,9]; var obj = {}; [].push.apply(obj,arr); console.log(obj) //伪数组转真数组 v ...
- (ETL)ETL架构师面试题(转载)
1. What is a logical data mapping and what does it mean to the ETL team?什么是逻辑数据映射?它对ETL项目组的作用是什么? 答: ...
- 网易新闻App架构重构实践:DDD正走向流行
网易新闻App架构重构实践:DDD正走向流行 https://mp.weixin.qq.com/s/FdwrT_xn3CQqpWoRVBttvQ 小智 InfoQ 2020-05-14 作者 | 小智 ...
- (转载)微软数据挖掘算法:Microsoft顺序分析和聚类分析算法(8)
前言 本篇文章继续我们的微软挖掘系列算法总结,前几篇文章已经将相关的主要算法做了详细的介绍,我为了展示方便,特地的整理了一个目录提纲篇:大数据时代:深入浅出微软数据挖掘算法总结连载,有兴趣的童鞋可以点 ...
- I/O 复用 multiplexing data race 同步 coroutine 协程
小结: 1.A file descriptor is considered ready if it is possible to perform the corresponding I/O opera ...