/*
比较简单的A* 估价函数很简单就是除了左上角的联通快之外的不同的个数
加上迭代 好像答案最多在16步之内出解
这样裸裸的交上去是50分
在考虑剪枝 每个选颜色的时候一定是选左上角联通快附近的颜色
处理一下只枚举这样的颜色 80 - 90 分了就
下面是代码
*/
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,ans,g[][],a[][],tot,color,falg,f[][],vis[],C;
int xx[]={,,-,};
int yy[]={,-,,};
int init()
{
int x=;char s=getchar();
while(s<''||s>'')s=getchar();
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x;
}
void Go(int x,int y,int c,int r)
{
a[x][y]=r;f[x][y]=;
for(int i=;i<;i++)
{
int nx=x+xx[i];
int ny=y+yy[i];
if(nx>&&nx<=n&&ny>&&ny<=n&&f[nx][ny]==&&a[nx][ny]==c)
Go(nx,ny,c,r);
}
}
void Get_round(int x,int y,int c,int round[])
{
f[x][y]=;
for(int i=;i<;i++)
{
int nx=x+xx[i];
int ny=y+yy[i];
if(nx>&&nx<=n&&ny>&&ny<=n&&f[nx][ny]==)
{
if(a[nx][ny]==c)Get_round(nx,ny,c,round);
else if(round[a[nx][ny]]==)round[a[nx][ny]]=;
}
}
}
void Dfs(int now,int sum)
{
if(falg)return;
memset(vis,,sizeof(vis));C=;
for(int i=;i<=n;i++)for(int j=;j<=n;j++)if(vis[a[i][j]]==){vis[a[i][j]]=;C++;}
if(now==sum)
{
if(C==)falg=;
return;
}
if(now+C->sum)return;
memset(f,,sizeof(f));
int round[];memset(round,,sizeof(round));
Get_round(,,a[][],round);
for(int i=;i<=;i++)
{
if(i==a[][]||round[i]==)continue;
int back[][];
memcpy(back,a,sizeof(a));
memset(f,,sizeof(f));
Go(,,a[][],i);
Dfs(now+,sum);if(falg)return;
memcpy(a,back,sizeof(back));
}
}
int main()
{
while()
{
n=init();if(n==)break;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
g[i][j]=init();
for(int k=;k<=;k++)
{
memcpy(a,g,sizeof(g));
falg=;Dfs(,k);
if(falg)
{
ans=k;break;
}
}
printf("%d\n",ans);
}
return ;
}
/*
只像上面那样好像A不了 (也可能是我常数太大了QAQ...)
最后没办法了 看了题解
每次灌水的时候似乎很慢
我们处理f数组 1表示已经在左上角 2表示在左上角的周围
这样不灌水 同样的处理了这个问题
虽然过了 但还是跑的比较慢.....
*/
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,ans,g[][],tot,color,falg,f[][],vis[],C;
int xx[]={,,-,};
int yy[]={,-,,};
int init()
{
int x=;char s=getchar();
while(s<''||s>'')s=getchar();
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x;
}
void dfs(int x,int y,int r)
{
f[x][y]=;
for(int i=;i<;i++)
{
int nx=x+xx[i];
int ny=y+yy[i];
if(nx>&&nx<=n&&ny>&&ny<=n&&f[nx][ny]==)
{
if(g[nx][ny]==r)dfs(nx,ny,r);
else f[nx][ny]=;
}
}
}
bool Go(int r)
{
int ret=;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(f[i][j]==&&g[i][j]==r)
ret=,dfs(i,j,r);
return ret;
}
void Dfs(int now,int sum)
{
if(falg)return;
memset(vis,,sizeof(vis));C=;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(vis[g[i][j]]==&&f[i][j]!=)
vis[g[i][j]]=,C++;
if(now==sum)
{
if(C==)falg=;
return;
}
if(now+C->sum)return;
int back[][];
memcpy(back,f,sizeof(f));
for(int i=;i<=;i++)
{
if(Go(i))Dfs(now+,sum);
if(falg)return;
memcpy(f,back,sizeof(back));
}
}
int main()
{
while()
{
n=init();if(n==)break;
memset(f,,sizeof(f));
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
g[i][j]=init();
dfs(,,g[][]);
for(int k=;k<=;k++)
{
falg=;Dfs(,k);
if(falg){ans=k;break;}
}
printf("%d\n",ans);
}
return ;
}

codevs 2495 水叮当的舞步IDA*的更多相关文章

  1. 【IDA*】codevs 2495:水叮当的舞步

    2495 水叮当的舞步 题目描述 Description 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变. 为了讨好她的偶像虹猫,水叮当决定在地毯上 ...

  2. codevs 2495 水叮当的舞步

    题目链接:水叮当的舞步 我现在开始发题目链接了(主要还是因为懒得整理题面)-- 这道题一开始是看到MashiroSky在写,于是我也开始写这道题了(说白了就是狙击他)-- 这道题看到这么小的范围当然给 ...

  3. bzoj3041 水叮当的舞步 IDA*

    水叮当的舞步 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 230  Solved: 107[Submit][Status][Discuss] Des ...

  4. 【wikioi】2495 水叮当的舞步(IDA*)

    http://wikioi.com/problem/2495/ 这题我还是看题解啊囧.(搜索实在太弱.完全没想到A*,还有看题的时候想错了,.,- -) 好吧,估价还是那么的简单,判断颜色不同的数目即 ...

  5. codevs2495 水叮当的舞步 IDA*

    我打暴力不对,于是就看看题解,,,,,,IDA*就是限制搜索深度而已,这句话给那些会A*但不知道IDA*是什么玩意的小朋友 看题解请点击这里 上方题解没看懂的看看这:把左上角的一团相同颜色的范围,那个 ...

  6. 【BZOJ3041】水叮当的舞步 迭代深搜IDA*

    [BZOJ3041]水叮当的舞步 Description 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变.为了讨好她的偶像虹猫,水叮当决定在地毯上跳 ...

  7. BZOJ 3041 水叮当的舞步

    3041: 水叮当的舞步 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 120  Solved: 67[Submit][Status][Discuss ...

  8. bzoj 3041: 水叮当的舞步 迭代加深搜索 && NOIP RP++

    3041: 水叮当的舞步 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 72  Solved: 44[Submit][Status] Descript ...

  9. [codevs2495]水叮当的舞步

    [codevs2495]水叮当的舞步 试题描述 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变. 为了讨好她的偶像虹猫,水叮当决定在地毯上跳一支轻盈 ...

随机推荐

  1. DOS命令行使用pscp实现远程文件和文件夹传输(转)

    转自 http://snailwarrior.blog.51cto.com/680306/141201   pscp是putty安装包所带的远程文件传输工具,使用和Linux下scp命令相似,具体的使 ...

  2. 【RabbitMQ】 Routing

    Routing 之前的章节里我们构建了一个简单的日志系统.我们可以广播所有的日志消息给所有的接收端. 本节我们将给它添加一个新特性 - 我们将允许只订阅一个消息的子集.例如,我们只将关键的错误消息定位 ...

  3. HTML5 display:inline、block、inline-block的区别--备用

    display:block就是将元素显示为块级元素. block元素的特点是: 总是在新行上开始: 高度,行高以及顶和底边距都可控制: 宽度缺省是它的容器的100%,除非设定一个宽度 <div& ...

  4. Unity3D RPC调用顺序问题

    使用Unity自带的Network实现多人协同任务时,因为使用RPC传递消息.RPC即远程过程调用,对于它的使用,第一反应的问题就是如果连续两次调用RPC,RPC的函数会顺序执行吗?还是只要RPC的消 ...

  5. 深入浅出 Java Concurrency (1) : J.U.C的整体认识

    转 http://www.blogjava.net/xylz/archive/2010/06/30/324915.html 去年年底有一个Guice的研究计划,可惜由于工作“繁忙”加上实际工作中没有用 ...

  6. html里的table如何在表格内部保留表格横线的同时去掉表格里的竖线

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. Java类加载的时机

    类是什么时候初始化的?类初始化的时候会执行static块,这个是我们知道的.那么我们可以用static块来做个实验. 上面代码输出是: hello worldinitthis is a test这说明 ...

  8. bzoj2561

    对于新加入的边,必须要既可能在最小生成树上也可能在最大生成树上我们先对于最小生成树考虑根据kruskal的理论,不难发现,u--v 长度为L的边可能出现在最小生成树上就是说删边剩下的比L小的边一定不能 ...

  9. 2015第37周二foxmail邮箱客户端迁移

    foxmail7.0邮箱客户端迁移风波浪费我下午不少时间,不知为何做完foxmail客户端在卡的时候我将其强制关闭,然后将整个邮箱目录拷贝到一台新电脑上,运行客户端居然我要新建账户(账户信息丢失),将 ...

  10. Fire Net(深搜 和一前不一样的深搜)

    /* http://acm.tzc.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=1162 本题妙处: 用一个数对行取商是 ...