MinimumTours TopCoder - 7620
Problem Statement |
|||||||||||||
| Little Bonnie has taken a vacation to Ha Long Bay. There are a few thousand stone islands in the bay, making it one of the most beautiful natural scenes in Vietnam. Bonnie is so impressed by this fact that she has decided to visit all of the islands. She bought a map of all the islands in the bay. This map is given in the String[] islandMap, which is a two-dimensional matrix where each cell is either '.' or lowercase 'x'. '.' cells represent sea and 'x' cells represent land. Two cells are connected if they have a point in common, so each cell may connect to at most 8 other cells. An island is defined as a maximal connected group of 'x' cells. A trip between two islands is defined as a connected group of '.' cells where, for each of the two islands, there is at least one '.' cell in the trip which is connected to a cell in that island. If there is no such connected group of '.' cells between two islands, then there is no trip between them. Note that an island can be nested inside another island. A tour is a sequence of islands where there is a trip between every pair of consecutive islands in the sequence. Little Bonnie wants to visit every island exactly once, and she wants to do this using the minimum possible number of tours. Return the number of tours she will have to take. | |||||||||||||
Definition |
|||||||||||||
|
|||||||||||||
Notes |
|||||||||||||
| - | It is possible for a tour to have only one island. | ||||||||||||
| - | Bonnie cannot leave the mapped area at any time. | ||||||||||||
| - | It is assumed that Bonnie has another way to travel from the last island of one tour to the first island of another tour, so you don't have to take this into account when solving the problem. | ||||||||||||
Constraints |
|||||||||||||
| - | islandMap will contain between 1 and 50 elements, inclusive. | ||||||||||||
| - | Each element of islandMap will contain between 1 and 50 characters, inclusive. | ||||||||||||
| - | Each element of islandMap will contain the same number of characters. | ||||||||||||
| - | Each character in islandMap will be either '.' or lowercase 'x'. | ||||||||||||
| - | There will be at least one island in the map. | ||||||||||||
Examples |
|||||||||||||
| 0) | |||||||||||||
|
|||||||||||||
| 1) | |||||||||||||
|
|||||||||||||
| 2) | |||||||||||||
|
|||||||||||||
| 3) | |||||||||||||
|
|||||||||||||
| 4) | |||||||||||||
|
|||||||||||||
代码
//将每一片海和岛看做一个点,构图发现这是一棵树
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
const int dx[]={-1,-1,-1,0,0,1,1,1};
const int dy[]={-1,0,1,-1,1,-1,0,1};
string s[60];
int a[1000][1000];
int n,m,cnt,wt,ans;
int head[100000];
bool used[3000][3000],is[100000],gone[100000];
struct edge{
int next,to;
}e[100000];
class MinimumTours
{
public:
//TC的格式
void ff(int x,int y,int col,int k){
if(a[x][y]!=k)return;
a[x][y]=col;
for(int i=0;i<8;i++)
ff(x+dx[i],y+dy[i],col,k);
}
void add(int u,int v){
e[++wt].next=head[u];
head[u]=wt;
e[wt].to=v;
e[++wt].next=head[v];
head[v]=wt;
e[wt].to=u;
}
int work(int v){
/*返回值含义:
0--对答案无贡献
1--有一条链,可向上走
2--是一个单点
*/
int i,k,cnt1=0,cnt2=0;
gone[v]=1;
for(i=head[v];i;i=e[i].next){
k=e[i].to;
if(!gone[k]){
k=work(k);
if(k==1)cnt1++;
if(k==2)cnt2++;
}
}
if(is[v]){
if(cnt1){
ans+=cnt1-1;
if(cnt1==1)return 1;
else return 0;
}
else {
if(cnt2)return 0;
return 2;
}
}
else {
if(cnt1==0)return cnt2>0;
ans+=cnt1/2;
return ((cnt1&1)?1:2);
}
}
int getMinimumTours(vector<string>islandMap)
{ //freopen("1.in","r",stdin);
int i,j,k;
cnt=0;wt=0;ans=0;
memset(head,0,sizeof(head));
n=islandMap.size();
m=islandMap[0].size();
for(i=0;i<n;i++)
for(j=0;j<m;j++)
a[i][j]=(islandMap[i][j]=='.'?-2:-1);
memset(used,0,sizeof(used));
memset(is,0,sizeof(is));
//构图
for(i=0;i<n;i++)
for(j=0;j<m;j++)
if(a[i][j]==-1){
ff(i,j,++cnt,-1);
is[cnt]=1;
}
for(i=0;i<n;i++)
for(j=0;j<m;j++)
if(a[i][j]==-2)ff(i,j,++cnt,-2);
for(i=0;i<n;i++)
for(j=0;j<m;j++)
for(k=0;k<8;k++){
int x1=i,x2=i+dx[k],y1=j,y2=j+dy[k];
int p=a[x1][y1],q=a[x2][y2];
if(p!=q&&q>0&&!used[p][q]){
used[p][q]=used[q][p]=1;
add(p,q);
}
}
memset(gone,0,sizeof(gone));
if(work(1)&&is[1])ans+=1;
return ans;
}
};
MinimumTours TopCoder - 7620的更多相关文章
- TopCoder kawigiEdit插件配置
kawigiEdit插件可以提高 TopCoder编译,提交效率,可以管理保存每次SRM的代码. kawigiEdit下载地址:http://code.google.com/p/kawigiedit/ ...
- 记第一次TopCoder, 练习SRM 583 div2 250
今天第一次做topcoder,没有比赛,所以找的最新一期的SRM练习,做了第一道题. 题目大意是说 给一个数字字符串,任意交换两位,使数字变为最小,不能有前导0. 看到题目以后,先想到的找规律,发现要 ...
- TopCoder比赛总结表
TopCoder 250 500 ...
- Topcoder几例C++字符串应用
本文写于9月初,是利用Topcoder准备应聘时的机试环节临时补习的C++的一部分内容.签约之后,没有再进行练习,此文暂告一段落. 换句话说,就是本文太监了,一直做草稿看着别扭,删掉又觉得可惜,索性发 ...
- TopCoder
在TopCoder下载好luncher,网址:https://www.topcoder.com/community/competitive%20programming/ 选择launch web ar ...
- TopCoder SRM 596 DIV 1 250
body { font-family: Monospaced; font-size: 12pt } pre { font-family: Monospaced; font-size: 12pt } P ...
- 求拓扑排序的数量,例题 topcoder srm 654 div2 500
周赛时遇到的一道比较有意思的题目: Problem Statement There are N rooms in Maki's new house. The rooms are number ...
- TopCoder SRM 590
第一次做TC,不太习惯,各种调试,只做了一题...... Problem Statement Fox Ciel is going to play Gomoku with her friend ...
- Topcoder Arena插件配置和训练指南
一. Arena插件配置 1. 下载Arena 指针:http://community.topcoder.com/tc?module=MyHome 左边Competitions->Algorit ...
随机推荐
- SSH三大框架的搭建整合(struts2+spring+hibernate)(转)
原文地址:http://blog.csdn.net/kyle0349/article/details/51751913 尊重原创,请访问原文地址 SSH说的上是javaweb经典框架,不能说100% ...
- java是用utf-16be编码方式编的。中文和英文都是两个字节
- android 网络编程--socket tcp/ip udp http之间的关系
网络七层由下往上分别为物理层.数据链路层.网络层.传输层.会话层.表示层和应用层,一般编程人员接触最多的就是应用层和运输层,再往下的就是所谓的媒体层了,不是我们研究的对象. 下面是应用层.运输层,网络 ...
- [原]NYOJ-216-A problem is easy
大学生程序代写 /*A problem is easy 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 When Teddy was a child , he was a ...
- freeMarker(十)——模板语言之内建函数
学习笔记,选自freeMarker中文文档,译自 Email: ddekany at users.sourceforge.net 1.字符串内建函数 这些内建函数作用于表达式左侧的字符串值. 如果左侧 ...
- Nodejs文件相关操作
欢迎关注我的博客我在马路边 适用人群 本文适用于刚接触Node的小白,毕竟我也是小白,大佬请绕行. Node文件操作 在实际开发中遇到很多有关文件及文件夹的操作,比如创建.删除文件及文件夹,文件拷贝. ...
- Mysql 排序null值 排序问题分析
mysql中null值的排序问题分析 如下表t_user: name age zhangsan 1 lisi NULL wangwu 2 www.2cto.com 执行一下sql: S ...
- ACM学习历程—HDU5587 Array(数学 && 二分 && 记忆化 || 数位DP)(BestCoder Round #64 (div.2) 1003)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5587 题目大意就是初始有一个1,然后每次操作都是先在序列后面添加一个0,然后把原序列添加到0后面,然后 ...
- bzoj 4260: REBXOR Trie+乱搞
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=4260 题解: 啊啊啊. 被这种SB题坑了半天. 求出异或前缀和后 从n到1枚举\(r_1 ...
- 一个内存增长问题的分析和处理(二)——valgrind工具的用法
valgrind是linux下对C++和C程序进行内存泄露检测的工具,除了内存检测,valgrind还提供了很多其他的功能,这里主要介绍下valgrind的内存检测的功能. 首先是文件的下载,valg ...