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

【样例输入1】
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

【样例输出1】
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]火星移民的更多相关文章

  1. BZOJ2283: [Sdoi2011]火星移民

    Description 在2xyz年,人类已经移民到了火星上.由于工业的需要,人们开始在火星上采矿.火星的矿区是一个边长为N的正六边形,为了方便规划,整个矿区被分为6*N*N个正三角形的区域(如图1) ...

  2. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  3. BZOJ 2243: [SDOI2011]染色 [树链剖分]

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6651  Solved: 2432[Submit][Status ...

  4. bzoj-2243 2243: [SDOI2011]染色(树链剖分)

    题目链接: 2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6267  Solved: 2291 Descript ...

  5. 【BZOJ2243】[SDOI2011]染色 树链剖分+线段树

    [BZOJ2243][SDOI2011]染色 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的 ...

  6. BZOJ 2286: [Sdoi2011]消耗战

    2286: [Sdoi2011消耗战 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2082  Solved: 736[Submit][Status] ...

  7. bzoj 2242: [SDOI2011]计算器 BSGS+快速幂+扩展欧几里德

    2242: [SDOI2011]计算器 Time Limit: 10 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description 你被 ...

  8. 【BZOJ】【2245】【SDOI2011】工作安排

    网络流/费用流 裸题吧……直接建模就好了……所谓的“分段函数”就是吓唬你的,其实就是对于每个人分开建几条流量不同.费用不同的弧而已. 对每种产品,连S->i ,(c[i],0):对每个工作人员 ...

  9. bzoj2243:[SDOI2011]染色

    链剖就可以了.一开始的想法错了.但也非常接近了.妈呀调的要死...然后把字体再缩小一号查错起来比较容易QAQ. #include<cstdio> #include<cstring&g ...

随机推荐

  1. Node.js meitulu图片批量下载爬虫1.04版

    //====================================================== // https://www.meitulu.com图片批量下载Node.js爬虫1. ...

  2. Vue工程模板文件 webpack打包

    1.github github地址:https://github.com/MengFangui/VueProjectTemplate 2.webpack配置 (1)基础配置webpack.base.c ...

  3. 使用LoadRunner监控Apache的步骤 (转)

    一.Apache上的设置 打开<Apache Installation>/conf/httpd.conf,进行如下修改: 1.  设置允许查看Apache运行状态的主机 # # Allow ...

  4. 由于删除DBF文件报错 —— ORA-01033: ORACLE initialization or shutdown in progress

    由于移动或删除DBF文件报错:ORA-01033: ORACLE initialization or shutdown in progress   原因:一般该类故障通常是由于移动文件而影响了数据库日 ...

  5. js中的 return false;

    总的来说return false 的作用就是阻止事件的默认行为 1. function check() { if(form.title.value=="") { alert(&qu ...

  6. Android学习笔记(一)——Activity简介 和 View

    源文链接:http://www.cnblogs.com/shyang--TechBlogs/archive/2011/03/14/1984195.html Android SDK ( Software ...

  7. javascript 字符串对象新增 replaceAll 方法

    String.prototype.replaceAll = function(reallyDo, replaceWith, ignoreCase) { if(! RegExp.prototype.is ...

  8. vb调试dll

    1.有两个工程BW_DetectCard.vbp(生成dll)及识别卡检测软件.vbp(生成exe) 2.打开工程<识别卡检测软件.vbp>,在文件--添加工程--现存,找到要引用的dll ...

  9. Hive row_number() 等用法

    1.row_number() over()排序功能: (1) row_number() over()分组排序功能: 在使用 row_number() over()函数时候,over()里头的分组以及排 ...

  10. DropFileName = "svchost.exe" 问题解决方案

    1.至以下链接处下载ATTK扫描工具: http://support.trendmicro.com.cn ... stomizedpackage.exe (32位) http://support.tr ...