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串然后首位和末位固定不变,从第二项开 ...
随机推荐
- 剑指offer 面试题2:实现Singleton模式
转自:https://blog.csdn.net/liang19890820/article/details/61615495 Singleton 的头文件(懒汉式/饿汉式公用): // single ...
- 剑指offer 面试题10.1:青蛙跳台阶
题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果). 编程思想 对于本题,前提只有 一次 1阶或者2阶的跳法.a.如果两种跳 ...
- mmall商城购物车模块总结
购物车模块的设计思想 购物车的实现方式有很多,但是最常见的就三种:Cookie,Session,数据库.三种方法各有优劣,适合的场景各不相同.Cookie方法:通过把购物车中的商品数据写入Cookie ...
- PAT甲级 1155 Heap Paths (30分) 堆模拟
题意分析: 给出一个1000以内的整数N,以及N个整数,并且这N个数是按照完全二叉树的层序遍历输出的序列,输出所有的整条的先序遍历的序列(根 右 左),以及判断整棵树是否是符合堆排序的规则(判断是大顶 ...
- 扩展PE头属性说明
CRC检测的算法就是checksum 以下是DllCharacteristics的参数说明
- gitignore 不起作用的解决办法 不再跟踪 让.gitignore生效,跟踪希望被跟踪的文件
实践 # https://git-scm.com/docs/gitignore https://git-scm.com/docs/gitignore 不跟踪log目录下的所有文件,但需要保留这个文件夹 ...
- SO_REUSEPORT 使用
https://www.cnblogs.com/Anker/p/7076537.html
- cpp异常机制思考
https://www.cnblogs.com/qq329914874/p/6734701.html
- 【题解】 CF767E Change-free
洛谷链接 这个题翻译忘了输入,我看的英语原文...... 首先,这是一道贪心题 我的大致方法:pair+堆优 题目分析: 从第一天开始,到最后一天,每天可以选择找钱或者不找钱. 如果不找钱,则零钱数m ...
- tricks - 思维
编辑 目录 tricks 系列 随机的性质 bitmask 建图 最基本的 黑白染色 Kruskal重构树 并查集维护值域 带根号的数三元环 根号分治 调和级数哈希 多属性哈希 时光倒流 时光反复横跳 ...