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]水叮当的舞步 试题描述 水叮当得到了一块五颜六色的格子形地毯作为生日礼物,更加特别的是,地毯上格子的颜色还能随着踩踏而改变. 为了讨好她的偶像虹猫,水叮当决定在地毯上跳一支轻盈 ...
随机推荐
- 【C语言】严格区分大小写
C语言严格区分大小写 一.相关基础知识 二.具体内容 C语言严格区分大小写: 如: int为关键字,INT则为用户标识符,即可定义int INT; int INt; int Int; cha ...
- hdu3652B-number
Problem Description A wqb-number, or B-number for short, is a non-negative integer whose decimal for ...
- 解决Maven中Missing artifact javax.jms:jms:jar:1.1:compile
搭建好项目后报错: Missing artifact javax.jms:jms:jar:1.1:compile 于POM.xml中 解决方案: 一 :在nexus中配置一个代理仓库 地址为 ...
- Idea设置自动导包
默认 IntelliJ IDEA 是没有开启自动 import 包的功能. 勾选标注 1 选项,IntelliJ IDEA 将在我们书写代码的时候自动帮我们优化导入的包,比如自动去掉一些没有用到的包 ...
- oracle常见sql积累
select lower('HELLO') from dual;select lpad(100, 5, '*') from dual;select sysdate + 1 / 24 from dual ...
- linux中bin和xbin下可执行程序的区别
/bin下的都是Linux最基础的,所有用户都可以使用的外部命令 /sbin下的都是只有超级用户root才能使用的.管理Linux系统的外部命令 /usr/bin以及/usr/local/bin下的都 ...
- 【Linux】常用命令 lsof查看打开的文件
Linux系统把软硬件都抽象成文件,所以通过文件可以追踪到很多重要信息,如读取的配置文件.打开的端口等. 下面是常见的用法: 默认测试文件名为text.txt 1,显示打开text.txt的进程: l ...
- 工作总结:qsort函数用法
qsort(&g_AMTBuf[g_dwAMTLenth], m_nCount, sizeof(12), Compare); 参数说明: 1.待排序数组首地址: 2.数组中待排序元素数量: 3 ...
- C#在父窗口中调用子窗口的过程(无法访问已释放的对象)异常,不存在从对象类型System.Windows.Forms.DateTimePicker到已知的托管提供程序本机类型的映射。
一:C#在父窗口中调用子窗口的过程(无法访问已释放的对象)异常 其实,这个问题与C#的垃圾回收有关.垃圾回收器管 理所有的托管对象,所有需要托管数据的.NET语言(包括 C#)都受运行库的 垃圾回收器 ...
- 安装ucenter 步骤详解及supesite 安装详解
最近弄一个 php 的cms ,花了周六日时间研究了一下,这里记录一下,首先在网页上下载ucenter(分为 gbk 或者utf8版本) 首先下载ucenter 之后,解压之后,upload 里的 ...