翻纸牌游戏

Time Limit : 9000/3000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other)
Total Submission(s) : 2   Accepted Submission(s) : 2
Problem Description
有一种纸牌游戏,很有意思,给你N张纸牌,一字排开,纸牌有正反两面,开始的纸牌可能是一种乱的状态(有些朝正,有些朝反),现在你需要整理这些纸牌。但是麻烦的是,每当你翻一张纸牌(由正翻到反,或者有反翻到正)时,他左右两张纸牌(最左边和最右边的纸牌,只会影响附近一张)也必须跟着翻动,现在给你一个乱的状态,问你能否把他们整理好,使得每张纸牌都正面朝上,如果可以,最少需要多少次操作。
 
Input
有多个case,每个case输入一行01符号串(长度不超过20),1表示反面朝上,0表示正面朝上。
 
Output
对于每组case,如果可以翻,输出最少需要翻动的次数,否则输出NO。
 
Sample Input
01 011
 
Sample Output
NO 1
题解:find函数应该放到最前,错了半天。。。
 代码1;
 #include<stdio.h>
#include<string.h>
#define MIN(x,y)(x<y?x:y)
int len,flot,ans;
int s[];
void turn(int x){
s[x]=!s[x];
if(x->=)s[x-]=!s[x-];
if(x+<len)s[x+]=!s[x+];
}
bool find(){
for(int i=;i<len;i++){
// printf("%d ",s[i]);
//if(s[i])puts("");
if(s[i])return false;
}
return true;
}
void dfs(int x,int time){
if(find()){
flot=;
ans=MIN(ans,time);
return;
}
if(x>=len)return;
dfs(x+,time);
turn(x);
dfs(x+,time+);
turn(x);
}
int main(){
char m[];
while(~scanf("%s",m)){
len=strlen(m);
for(int i=;i<len;i++)s[i]=m[i]-'';
s[len]='\0';
ans=0x3f3f3f3f;
flot=;
dfs(,);
//printf("%d\n",ans);
if(flot)printf("%d\n",ans);
else puts("NO");
}
return ;
}

代码2;

 #include<stdio.h>
#include<string.h>
#define MIN(x,y)(x<y?x:y)
int len,flot,ans;
int s[],cnt[];
void turn(int x){
s[x]=!s[x];
if(x->=)s[x-]=!s[x-];
if(x+<len)s[x+]=!s[x+];
}
bool find(){
for(int i=;i<len;i++){
// printf("%d ",s[i]);
//if(s[i])puts("");
if(s[i])return false;
}
return true;
}
void dfs(int x){
if(find()){
flot=;
int temp=;
for(int i=;i<len;i++)if(cnt[i]==)temp++;
ans=MIN(ans,temp);
return;
}
if(x>=len)return;
for(cnt[x]=;cnt[x]<;){
turn(x);
cnt[x]++;
dfs(x+);
}
}
int main(){
char m[];
while(~scanf("%s",m)){
len=strlen(m);
for(int i=;i<len;i++)s[i]=m[i]-'';
s[len]='\0';
ans=0x3f3f3f3f;
flot=;
memset(cnt,,sizeof(cnt));
dfs();
//printf("%d\n",ans);
if(flot)printf("%d\n",ans);
else puts("NO");
}
return ;
}

翻纸牌游戏(dfs回溯)的更多相关文章

  1. HDU 2209 翻纸牌游戏(DFS)

    题目链接 Problem Description 有一种纸牌游戏,很有意思,给你N张纸牌,一字排开,纸牌有正反两面,开始的纸牌可能是一种乱的状态(有些朝正,有些朝反),现在你需要整理这些纸牌.但是麻烦 ...

  2. hdu2209翻纸牌游戏

    翻纸牌游戏 Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  3. HDU 2209 翻纸牌游戏 状态BFS

    翻纸牌游戏 Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem De ...

  4. HDU 2209 翻纸牌游戏

    翻纸牌游戏 Time Limit : 9000/3000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submiss ...

  5. hdu 2209 翻纸牌游戏【贪心】

    本来是冲着搜索去的--其实可以贪心 因为能改变第一位的只有第一位和第二位,然后改完之后后面的同理,也就是说只要贪心的推一遍就可以 但是注意要在翻第一个和不翻第一个之间取个min #include< ...

  6. 【HDOJ】2209 翻纸牌游戏

    状态压缩+双向广搜.注意控制时间t. /* 2209 */ #include <iostream> #include <string> #include <map> ...

  7. 翻纸牌 高校俱乐部 英雄会 csdn

    题目描述 有一种纸牌游戏,很有意思,给你N张纸牌,一字排开,纸牌有正反两面,开始的纸牌可能是一种乱的状态(有些朝正,有些朝反),现在你需要整理这些纸牌.但是麻烦的是,每当你翻一张纸牌(由正翻到反,或者 ...

  8. P1074 靶形数独 dfs回溯法

    题目描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z 博士请教,Z 博士拿出了他最近发明的“靶 ...

  9. [Usaco2007 Open]Fliptile 翻格子游戏题解

    问题 B: [Usaco2007 Open]Fliptile 翻格子游戏 时间限制: 5 Sec  内存限制: 128 MB 题目描述 Farmer John knows that an intell ...

随机推荐

  1. PHP之MVC微型框架简单搭建

    好长时间没有写博客了,这段时间过得紧张的不行,以致于都没有抽出时间来好好的总结一下自己这段时间的生活和学习. 其实今天不想写什么技术博客,就想简单总结一下这段时间的生活.10月8号从家里回来以后决定自 ...

  2. JS中的prototype属性

    JavaScript是基于对象的,任何元素都可以看成对象.然而,类型和对象是不同的.本文中,我们除了讨论类型和对象的一些特点之外,更重要的 是研究  如何写出好的并且利于重用的类型.毕竟,JavaSc ...

  3. Oracle EBS-SQL (SYS-12):查询各Profile的设置情况.sql

    SELECT pro.profile_option_name, pro.user_profile_option_name, lev.level_type TYPE, --lev.level_code, ...

  4. Cortex-M3学习日志(一)-- GPIO实验

    因为项目所需,所以不得不开始研究M3,我用的是NXP公司的LPC1768这个芯片,它是具有三级流水线的哈佛结构,带独立的本地指令和数据总线以及用于外设的稍微低性能的第三条总线,还包含一个支持随机跳转的 ...

  5. [原]CAS和Shiro在spring中集成

    shiro是权限管理框架,现在已经会利用它如何控制权限.为了能够为多个系统提供统一认证入口,又研究了单点登录框架cas.因为二者都会涉及到对session的管理,所以需要进行集成. Shiro在1.2 ...

  6. Robot Framework作者建议如何选择自动化测试框架

    本文摘自:InfoQ中文站http://www.infoq.com/cn/news/2012/06/robot-author-suggest-autotest Robot Framework作者建议如 ...

  7. mojo 接口示例

    <pre name="code" class="python">use Mojolicious::Lite; use JSON qw/encode_ ...

  8. Ubuntu下获取Nexus7的Root权限

    一.准备 下载获取Root权限的工具包. 下载地址: http://downloadandroidrom.com/file/Nexus7/rooting/Nexus7Root.zip 二.解锁 Ubu ...

  9. UVA507-- Jill Rides Again

    题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  10. loading android

    drawal/loading.xml <?xml version="1.0" encoding="utf-8"?><animated-rota ...