[Sdoi2011]火星移民
2283: [Sdoi2011]火星移民
Time Limit: 40 Sec Memory Limit: 512 MB
Submit: 119 Solved: 56
[Submit][Status][Discuss]
Description
在2xyz年,人类已经移民到了火星上。由于工业的需要,人们开始在火星上采矿。火星的矿区是一个边长为N的正六边形,为了方便规划,整个矿区被分为6*N*N个正三角形的区域(如图1)。
整个矿区中存在A矿,B矿,C矿三个矿场,和a厂,b厂,c厂三个炼矿厂。每个三角形的区域可以是一个矿场、炼矿厂、山地、或者平地。现在矿区管理局要求建立一个交通系统,使得矿场和对应炼矿厂之间存在一条公路,并且三条公路互不交叉(即一个三角形区域中不存在两条以上运输不同矿的公路)。两个三角形区域是相邻的当且仅当这两个三角形存在公共边,只有相邻的两个区域之间才能建一段路,建这段路的费用为1。注意,山地上是不能建公路的。由于火星金融危机的影响,矿区管理局想知道建立这样一个交通系统最少要花多少费用。更多的,当局向知道有多少种花费最小的方案。
Input
第1行一个整数N。表示这个矿区是边长为N的正六边形。
接下来有6*N*N的整数,分为2*N行,表示矿区当前区域的情况。0表示平地,1,2,3表示对应的矿区或者炼矿厂,4表示山地。(样例1对应图2)。可能有多组数据,请处理到文件结尾
Output
对于每组数据,包含两个整数,表示最小费用和达到最小费用的方案数。如果找不到符合要求的方案,输出-1 -1。由于方案数可能过大,所以请把方案数mod 1000000007
Sample Input
2
0 1 0 0 0
0 0 2 0 4 0 0
0 0 4 3 0 3 2
0 0 0 1 0
【样例输入2】
3
0 0 0 1 0 0 0
0 0 0 0 0 0 0 0 0
0 0 2 0 0 0 0 0 0 0 0
0 0 0 0 0 0 3 0 0 0 0
0 0 0 0 0 0 0 0 0
0 3 0 1 0 2 0
Sample Output
18 1
【样例输出2】
44 1
HINT
样例2的解释
对于100%的数据,N≤6
Source
//40分dfs
//插头dp不会
#include<cstdio>
#include<cstring>
using namespace std;
const int N=;
const int dx[][]={{,,},{-,,}};
const int dy[][]={{,,-},{,,-}};
int n,sx[],sy[],ex[],ey[],mp[N][N];bool vis[N][N];
int ans,sum;
inline void Cl(){
memset(mp,-,sizeof mp);
memset(vis,,sizeof vis);
memset(sx,,sizeof sx);
memset(sy,,sizeof sy);
memset(ex,,sizeof ex);
memset(ey,,sizeof ey);
}
inline void init(){
for(int i=;i<=n;i++){
for(int j=n-i+;j<=n*+i-;j++){
scanf("%d",&mp[i][j]);
int &db=mp[i][j];
if(db>&&db<){
if(!sx[db]) sx[db]=i,sy[db]=j;
else ex[db]=i,ey[db]=j;
}
}
}
for(int i=;i<=n;i++){
for(int j=i;j<=n*-i;j++){
scanf("%d",&mp[i+n][j]);
int &db=mp[i+n][j];
if(db>&&db<){
if(!sx[db]) sx[db]=i+n,sy[db]=j;
else ex[db]=i+n,ey[db]=j;
}
}
}
}
void dfs(int now,int x,int y,int cost){
if(x==ex[now]&&y==ey[now]){
if(now<){
vis[sx[now+]][sy[now+]]=;
dfs(now+,sx[now+],sy[now+],cost);
vis[sx[now+]][sy[now+]]=;
}
else{
if(cost==ans) sum++;
if(cost<ans) ans=cost,sum=;
}
return ;
}
int p=!((x+y&)^(n&));
for(int i=,nx,ny;i<;i++){
nx=x+dx[p][i];ny=y+dy[p][i];
if(!vis[nx][ny]&&(!mp[nx][ny]||mp[nx][ny]==now)){
vis[nx][ny]=;
dfs(now,nx,ny,cost+);
vis[nx][ny]=;
}
}
}
inline void work(){
Cl();init();
ans=2e9;sum=;
vis[sx[]][sy[]]=;
dfs(,sx[],sy[],);
if(sum) printf("%d %d\n",ans,sum);
else printf("-1 -1\n");
}
int main(){
freopen("mars.in","r",stdin);
freopen("mars.ans","w",stdout);
while(~scanf("%d",&n)) work();
return ;
}
[Sdoi2011]火星移民的更多相关文章
- BZOJ2283: [Sdoi2011]火星移民
Description 在2xyz年,人类已经移民到了火星上.由于工业的需要,人们开始在火星上采矿.火星的矿区是一个边长为N的正六边形,为了方便规划,整个矿区被分为6*N*N个正三角形的区域(如图1) ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 2243: [SDOI2011]染色 [树链剖分]
2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6651 Solved: 2432[Submit][Status ...
- bzoj-2243 2243: [SDOI2011]染色(树链剖分)
题目链接: 2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6267 Solved: 2291 Descript ...
- 【BZOJ2243】[SDOI2011]染色 树链剖分+线段树
[BZOJ2243][SDOI2011]染色 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的 ...
- BZOJ 2286: [Sdoi2011]消耗战
2286: [Sdoi2011消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2082 Solved: 736[Submit][Status] ...
- bzoj 2242: [SDOI2011]计算器 BSGS+快速幂+扩展欧几里德
2242: [SDOI2011]计算器 Time Limit: 10 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description 你被 ...
- 【BZOJ】【2245】【SDOI2011】工作安排
网络流/费用流 裸题吧……直接建模就好了……所谓的“分段函数”就是吓唬你的,其实就是对于每个人分开建几条流量不同.费用不同的弧而已. 对每种产品,连S->i ,(c[i],0):对每个工作人员 ...
- bzoj2243:[SDOI2011]染色
链剖就可以了.一开始的想法错了.但也非常接近了.妈呀调的要死...然后把字体再缩小一号查错起来比较容易QAQ. #include<cstdio> #include<cstring&g ...
随机推荐
- Centos 7 进入单用户模式图文详解
由于昨晚做了一个很傻X的事情,所以有幸进入了CentOS 7 的单用户模式. CentOS 7 在进入单用户的时候和6.x做了很多的改变, 下面让我们来看看如何进入单用户模式. 如何进入CentOS ...
- servlet--百度百科
Servlet(Server Applet),全称Java Servlet, 未有中文译文.是用Java编写的服务器端程序.其主要功能在于交互式地浏览和修改数据,生成动态Web内容.狭义的Servle ...
- 基于React实现的【绿色版电子书阅读器】,支持离线下载
代码地址如下:http://www.demodashi.com/demo/12052.html MyReader 绿色版电子书阅读器 在线地址:http://myreader.linxins.com ...
- 正则化--L1正则化(稀疏性正则化)
稀疏矢量通常包含许多维度.创建特征组合会导致包含更多维度.由于使用此类高维度特征矢量,因此模型可能会非常庞大,并且需要大量的 RAM. 在高维度稀疏矢量中,最好尽可能使权重正好降至 0.正好为 0 的 ...
- robot.txt 文件 作用和语法
seo工作者应该不陌生,robots.txt文件是每一个搜索引擎蜘蛛到你的网站之后要寻找和访问的第一个文件,robots.txt是你对搜索引擎制定的一个如何索引你的网站的规则.通过该文件,搜索引擎就可 ...
- Atitit.json类库的设计与实现 ati json lib
Atitit.json类库的设计与实现 ati json lib 1. 目前jsonlib库可能有问题,可能版本冲突,抛出ex1 2. 解决之道:1 2.1. 自定义json解析库,使用多个复合的js ...
- mybatis 使用注解实现多参数传递
若映射器中的方法只有一个参数,则在对应的SQL语句中,可以采用#{参数名}的方式来引用此参数,以前的例子多属于此类.但这种方法却不适用于需要传递多个参数的情况,今天就来介绍如何使用注解传递多个参数 一 ...
- wait
package money.thread; import money.Log; public class AddRunner extends ExecutableRunner { private st ...
- flink 问题记录
转发请注明原创地址:http://www.cnblogs.com/dongxiao-yang/p/7652337.html 1 WindowFunction类型不匹配无法编译. flink 版本:1. ...
- 283. Move Zeroes【easy】
283. Move Zeroes[easy] Given an array nums, write a function to move all 0's to the end of it while ...