/*
比较简单的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. Linux系统管理技术手册——第6章 添加新用户

    6.1/etc/passwd文件 用户登录时Linux识别用户的文件/etc/passwd /etc/passwd包括7个字段: 登录名(不超过32位,使用NIS系统后不超过8位) 经过加密的口令或口 ...

  2. windows phone 8学习 - 选择器

    1照相机 CameraCaptureTask cct=new CameraCaptureTask(); cct.Completed+=new EventHandler<PhotoResult&g ...

  3. ORACLE WIN7安装过程截图

    尽管 有点不正规,但还可以.

  4. 关于判断变量是否为null的顺序问题。

    if("y".equals(other)){ } 其中,other字符串变量可能为Null,可以加一个null判断或者将常量写在前面,变量写在equals后面.如果将变量other ...

  5. 优秀的开发者 vs. 差的开发者

    优秀的开发者是一个艺术家,一个享受创作过程的工匠.差的开发者只将自己当作负责产生代码的码农. 优秀的开发者了解客户的问题.差的开发者只了解手头的技术问题.优秀的开发者会不断努力去理解"为什么 ...

  6. Maven实战四

    转载:http://www.iteye.com/topic/1123231 为什么要定义Maven坐标      在我们开发Maven项目的时候,需要为其定义适当的坐标,这是Maven强制要求的.在这 ...

  7. ikely()与unlikely() 都等同于if, 此处只是做编译优化

    ikely()与unlikely()在2.6内核中,随处可见,那为什么要用它们?它们之间有什么区别呢? 首先明确: if (likely(value))等价于if (value)if (likely( ...

  8. bzoj1978

    朴素的算法是O(n2logn)观察这个算法,似乎很难在进行优化我们就要换一种思路考虑到一个数的约数总不是很多,穷举约数也是可以在O(sqrt(x))的时间内完成的并且注意到,能否继续往下选数,只在于最 ...

  9. UVA-10735 - Euler Circuit(混合欧拉回路输出)

    题意:给你一个图,有N个点,M条边,这M条边有的是单向的,有的是双向的. 问你能否找出一条欧拉回路,使得每条边都只经过一次! 分析: 下面转自别人的题解: 把该图的无向边随便定向,然后计算每个点的入度 ...

  10. Linux Shell编程(6)——变量替换

    变量的名字是它的值保存的地方.引用它的值称为变量替换.$让我们仔细地区别变量和变量的值.如果variable1是一个变量的名字,那么$variable1就是引用这个变量的值――即这个变量它包含的数据. ...