codevs 2495 水叮当的舞步IDA*
/*
比较简单的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*的更多相关文章
- 【IDA*】codevs 2495:水叮当的舞步
2495 水叮当的舞步 题目描述 Description 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变. 为了讨好她的偶像虹猫,水叮当决定在地毯上 ...
- codevs 2495 水叮当的舞步
题目链接:水叮当的舞步 我现在开始发题目链接了(主要还是因为懒得整理题面)-- 这道题一开始是看到MashiroSky在写,于是我也开始写这道题了(说白了就是狙击他)-- 这道题看到这么小的范围当然给 ...
- bzoj3041 水叮当的舞步 IDA*
水叮当的舞步 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 230 Solved: 107[Submit][Status][Discuss] Des ...
- 【wikioi】2495 水叮当的舞步(IDA*)
http://wikioi.com/problem/2495/ 这题我还是看题解啊囧.(搜索实在太弱.完全没想到A*,还有看题的时候想错了,.,- -) 好吧,估价还是那么的简单,判断颜色不同的数目即 ...
- codevs2495 水叮当的舞步 IDA*
我打暴力不对,于是就看看题解,,,,,,IDA*就是限制搜索深度而已,这句话给那些会A*但不知道IDA*是什么玩意的小朋友 看题解请点击这里 上方题解没看懂的看看这:把左上角的一团相同颜色的范围,那个 ...
- 【BZOJ3041】水叮当的舞步 迭代深搜IDA*
[BZOJ3041]水叮当的舞步 Description 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变.为了讨好她的偶像虹猫,水叮当决定在地毯上跳 ...
- BZOJ 3041 水叮当的舞步
3041: 水叮当的舞步 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 120 Solved: 67[Submit][Status][Discuss ...
- bzoj 3041: 水叮当的舞步 迭代加深搜索 && NOIP RP++
3041: 水叮当的舞步 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 72 Solved: 44[Submit][Status] Descript ...
- [codevs2495]水叮当的舞步
[codevs2495]水叮当的舞步 试题描述 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变. 为了讨好她的偶像虹猫,水叮当决定在地毯上跳一支轻盈 ...
随机推荐
- gcc常用的编译选项
一.程序编译过程 程序编译的时候,要分四个阶段 : 1.预处理阶段,完成宏定义和include文件展开等工作: 2.根据编译参数进行不同程度的优化,编译成汇编代码: 3.用汇编器把汇编代码进一步生成目 ...
- SQL语句操作大全
SQL语句操作大全 本文分为以下六个部分: 基础部分 提升部分 技巧部分 数据开发–经典部分 SQL Server基本函数部分 常识部分 一.基础 1.说明:创建数据库CREATE DATABAS ...
- jquery $(this).attr $(this).val方法使用介绍--useful
$(this).attr(key); 获取节点属性名的值,相当于getAttribute(key)方法,本文整理了一些相关的示例,感兴趣的朋友可以参考下 $(this).attr(key); 获取节点 ...
- Kent Beck揭秘Facebook开发部署流程
http://www.infoq.com/cn/news/2013/10/facebook-development-deployment Facebook是世界上最大的社交网站,有超过10亿用户每月至 ...
- Adobe Photoshop CS或者CC卸载不了怎么办?
有木有没有遇到这个问题的同学?使用Adobe Creative Suite CleanerToo工具下载就好了~ 下载地址:http://pan.baidu.com/s/1pJ3aBsn
- BZOJ 1507 Editor
Description Input 输入文件editor.in的第一行是指令条数t,以下是需要执行的t个操作.其中: 为了使输入文件便于阅读,Insert操作的字符串中可能会插入一些回车符,请忽略掉它 ...
- Door man
poj1300:http://poj.org/problem?id=1300 题意:给你n个房间,房间之间有一些门,房间是按0~~n-进行编号的.然后给出一些房间的之间门,n行,每行的数字表示该们与其 ...
- YII 主题
heming是一个在Web应用程序里定制网页外观的系统方式.通过采用一个新的主题,网页应用程序的整体外观可以立即和戏剧性的改变. 在Yii,每个主题由一个目录代表,包含view文件,layout文件和 ...
- ♫【JS】offsetParent
This property will return null on Webkit if the element is hidden (the style.display of this element ...
- SQL 2005远程连接是出错(provider: SQL 网络接口, error: 28 - 服务器不支持请求的协议
SQL 2005远程连接是出错(provider: SQL 网络接口, error: 28 - 服务器不支持请求的协议 sql远程连接服务器网络sql serversqlserver 解决方法:在服务 ...