题目链接:水叮当的舞步

  我现在开始发题目链接了(主要还是因为懒得整理题面)……

  这道题一开始是看到MashiroSky在写,于是我也开始写这道题了(说白了就是狙击他)……

  这道题看到这么小的范围当然给人的第一感觉就是搜索了。于是我果断写了个搜索,后果很惨……我都没敢交上去……

  后来想了各种优化,一路优化到了$80$分。最后的我想不出来了,于是就去翻了题解,终于弄全了。

  首先,这道题最好使用迭代加深搜索。因为普通的$dfs$太慢,而$bfs$空间又开不下(听说某位大神使用$bfs$切掉了)。

  接下来就是各种剪枝。每次都要对左上角的联通块进行拓展,这一步很耗时间。于是我们可以考虑给每个格子染上色,已经在左上角联通块内的染为$1$,在边上的染为$2$,其余的就是$3$了。于是每次拓展的时候我们只需可以找出所有颜色为$2$(是我们自己染上的颜色)的格子进行拓展即可。

  然后我们可以对当前状态进行估价。设联通块外的颜色(输入的颜色)数为$x$,那么至少需要$x$步才可以让剩下的格子颜色相同。减掉一批。

  另外还剩下一个,那就是当改变颜色后左上角联通块大小没有改变,那么这一步染色是无效的,可以直接减掉。

  大概就是这些了。这道题用到了估价函数,那么就是$A*$搜索?

  下面贴代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define N 9 using namespace std; int a[N][N],n,now;//a数组是输入的颜色,co数组是我自己染的颜色
int co[N][N],ans,yan[6],sheng;//yan数组标记剩下的每种颜色的数目,sheng就是剩余的不同种类颜色数
int zx[4]={1,-1,0,0},zy[4]={0,0,1,-1}; void color(int x,int y){//将(x,y)所在联通块纳入左上角联通块
if(!(--yan[a[x][y]])) sheng--;
co[x][y]=1; now++;
for(int k=0,i,j;k<4;k++){
i=x+zx[k],j=y+zy[k];
if(i>=1 && i<=n && j>=1 && j<=n && co[i][j]!=1){
if(a[i][j]==a[x][y]) color(i,j);
else co[i][j]=2;
}
}
} bool pd(int x){//判断联通块大小是否改变,顺便进行染色
bool ww=0;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(co[i][j]==2 && a[i][j]==x)
color(i,j),ww=1;
return ww;
} bool dfs(int d){
if(sheng>d) return 0;
if(now==n*n) return 1;
if(!d) return 0;
int zan[N][N],col[6],nn=now,ns=sheng;
for(int i=0;i<6;i++){
memcpy(zan,co,sizeof(co));
memcpy(col,yan,sizeof(yan));
if(pd(i)){
if(dfs(d-1)) return 1;
memcpy(co,zan,sizeof(co));
memcpy(yan,col,sizeof(yan));
now=nn;sheng=ns;
}
}
return 0;
} int main(){
File("a");
while(scanf("%d",&n)==1 && n){
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++){
scanf("%d",&a[i][j]);
co[i][j]=3;
}
now=sheng=0; color(1,1); yan[a[1][1]]=0;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(co[i][j]!=1) if(!(yan[a[i][j]]++)) sheng++;
for(ans=0;;ans++)
if(dfs(ans)){
printf("%d\n",ans);
break;
}
}
return 0;
}

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

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

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

  2. codevs 2495 水叮当的舞步IDA*

    /* 比较简单的A* 估价函数很简单就是除了左上角的联通快之外的不同的个数 加上迭代 好像答案最多在16步之内出解 这样裸裸的交上去是50分 在考虑剪枝 每个选颜色的时候一定是选左上角联通快附近的颜色 ...

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

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

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

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

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

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

  6. [codevs2495]水叮当的舞步

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

  7. bzoj3041 水叮当的舞步 IDA*

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

  8. BZOJ 3041 水叮当的舞步

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

  9. Bzoj3041 水叮当的舞步

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 132  Solved: 75 Description 水叮当得到了一块五颜六色的格子形地毯作为生日礼物 ...

随机推荐

  1. GJM : Unity调用系统窗口选择本地文件

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  2. 解决eclipse配置Tomcat时找不到server选项(Mac通用)

    集成Eclipse和Tomcat时找不到server选项: 按照网上的步骤如下: 在Eclipse中,窗口(window)——首选项(preferences)——服务器(Server)——运行时环境( ...

  3. javascript面试题:如何把一句英文每个单词首字母大写?

    上周看到大家在JS群讨论如何把一句英文句子单词收割字母大写,大家都说用正则简单,对于正则还是有点模糊,于是乎自己敲了下 //面试题:如何把一句英文每个单词首字母大写? var str="wh ...

  4. Bootstrap栅格布局系统的特点

    栅格布局系统的特点: (1)所有的行必须放在容器中: .container或.container-fluid (2)分为多行(row),一行中平均分为12列(col) (3)网页内容只能放在列(col ...

  5. js中的等值运算符(抽象相等==与严格相等===的区别)

    js中的等值运算符 js中的相等分为抽象相等和严格相等,他们有什么区别呢. 在说具体算法前,先提下JS数据类型,JS数据类型分为6类:Undefined Null String Number Bool ...

  6. iOS开发中<null>的处理

    在iOS开发过程中经常需要与服务器进行数据通讯,JSON就是一种常用的高效简洁的数据格式. 问题: 在项目中,一直遇到一个坑的问题,程序在获取某些数据之后莫名崩溃.原因是:由于服务器的数据库中有些字段 ...

  7. 在C#开发中如何使用Client Object Model客户端代码获得SharePoint 网站、列表的权限情况

    自从人类学会了使用火,烤制的方式替代了人类的消化系统部分功能,从此人类的消化系统更加简单,加速了人脑的进化:自从SharePoint 2010开始有了Client Side Object Model ...

  8. 【Swift】UITableViewCell 中 TTTAttributedLabel 超链接无法点击的问题

    前言 还以为是自己代码写的有问题,用法和别的地方都一样,但是这个是在 UITableViewCell 中使用,另外在 tableHeaderView 中使用也没用这个问题 —— 使用 TTTAttri ...

  9. 学习tensorflow之mac上安装tensorflow

    背景 听说谷歌的第二代机器学习的框架tensorflow开源了,我也心血来潮去探探大牛的产品.怎奈安装就折腾了一天,现在整理出来备忘. tensorflow官方网站给出的安装步骤很简单: # Only ...

  10. VIEW SERVER STATE permission was denied on object 'server', database 'master'

    今天一同事反馈使用SQL Server 2012 Management Studio连接SQL Server 2014后,选择数据库中某个表,然后单击右键时,就会遇到下面错误: 这个错误初看以为是权限 ...