24点游戏

Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)
Submit Status

2424点就是给你一串数字,问你是否通过加减乘除括号构成2424点。

沈爷觉得这个很好玩,就决定考考你,给你44个数,可以交换位置,可以用加减乘除和括号,是否能构成2424点呢?

注意哦~这里的除法并不是整数除法,比如样例

Input

第一行TT,表示有多少组测试数据,1≤T≤501≤T≤50

接下来TT行,每行44个正整数a1a1, a2a2, a3a3, a4a4,表示每个数都是多少,1≤ai≤131≤ai≤13

Output

对于每一次询问,如果能够凑成2424点,输出yes,否则输出no

Sample input and output

Sample Input Sample Output
2
3 3 8 8
1 1 1 1
yes
no

Hint

33 33 88 88

就可以构造出 8÷(3–8÷3)=24

题解:求24点,暴力搜索下就好,刚开始我想着全排列下,然后按照顺序来进行,但是思路明显不完善,然后看了大神的,

大神是延长数组存放当前运算的解,vis记录是否用过,思路很巧妙;很简单就A过了;

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<map>
#include<string>
#include<vector>
using namespace std;
const int INF=0x3f3f3f3f;
#define SI(x) scanf("%d",&x)
#define PI(x) printf("%d",x)
#define P_ printf(" ")
#define mem(x,y) memset(x,y,sizeof(x))
typedef long long LL;
int flot;
double a[];
int vis[];
/*void dfs(int pos,double cur);
void ary(int num){
if(flot)return;
if(num==4){
// for(int i=0;i<4;i++)printf("%d ",ans[i]);puts("");
dfs(1,ans[0]);
return;
}
for(int i=0;i<4;i++){
if(vis[i])continue;
ans[num]=a[i];
vis[i]=1;
ary(num+1);
vis[i]=0;
}
}
*/
void dfs(int usd,int tp){
if(flot)return;
if(usd==){
if(abs(a[tp-]-)<1e-)flot=;
return;
}
/*
dfs(pos+1,cur+ans[pos]);
dfs(pos+1,cur-ans[pos]);
dfs(pos+1,cur*ans[pos]);
dfs(pos+1,cur/ans[pos]);
dfs(pos+1,-cur*ans[pos]);
dfs(pos+1,-cur/ans[pos]);
dfs(pos+1,ans[pos]/cur);
dfs(pos+1,ans[pos]/cur);
*/
for(int i=;i<tp;i++){
if(vis[i])continue;
vis[i]=;
for(int j=i+;j<tp;j++){
if(vis[j])continue;
vis[j]=;
a[tp]=a[i]+a[j];dfs(usd+,tp+);
a[tp]=a[i]*a[j];dfs(usd+,tp+);
a[tp]=a[i]-a[j];dfs(usd+,tp+);
a[tp]=a[j]-a[i];dfs(usd+,tp+);
if(a[i]!=){
a[tp]=a[j]/a[i];dfs(usd+,tp+);
}
if(a[j]!=){
a[tp]=a[i]/a[j];dfs(usd+,tp+);
}
vis[j]=;
}
vis[i]=;
}
}
int main(){
int T;
SI(T);
while(T--){
for(int i=;i<;i++)scanf("%lf",&a[i]);
flot=;
mem(vis,);
dfs(,);
if(flot)puts("yes");
else puts("no");
}
return ;
}

速算24点

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 4250    Accepted Submission(s): 1044

Problem Description
速算24点相信绝大多数人都玩过。就是随机给你四张牌,包括A(1),2,3,4,5,6,7,8,9,10,J(11),Q(12),K(13)。要求只用'+','-','*','/'运算符以及括号改变运算顺序,使得最终运算结果为24(每个数必须且仅能用一次)。游戏很简单,但遇到无解的情况往往让人很郁闷。你的任务就是针对每一组随机产生的四张牌,判断是否有解。我们另外规定,整个计算过程中都不能出现小数。
 
Input
每组输入数据占一行,给定四张牌。
 
Output
每一组输入数据对应一行输出。如果有解则输出"Yes",无解则输出"No"。
 
Sample Input
A 2 3 6
3 3 8 8
 
Sample Output
Yes
No

题解:跟上题不同的是,这个是字符输入,而且,是整除的;注意10的读入。。。

虽然写过,但是比赛出到还是不会。。。这个题思路就是dfs,a[tp - 1]代表当前usd的个数的计算值。

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
using namespace std;
int a[];
int vis[];
int ans;
void dfs(int usd, int tp){
if(ans)return;
if(usd == ){
if(a[tp - ] == )ans = ;
return;
}
for(int i = ; i < tp; i++){
if(vis[i])continue;
vis[i] = ;
for(int j = i + ; j < tp; j++){//注意应该从i + 1开始,可以让时间减少一般否则会超时;
if(vis[j])continue;
vis[j] = ;
a[tp] = a[i] + a[j];dfs(usd + , tp + );
a[tp] = a[i] - a[j];dfs(usd + , tp + );
a[tp] = a[j] - a[i];dfs(usd + , tp + );
a[tp] = a[i] * a[j];dfs(usd + , tp + ); if(a[j] != && a[i] % a[j] == ){
a[tp] = a[i] / a[j];dfs(usd + , tp + );
}
if(a[i] != && a[j] % a[i] == ){
a[tp] = a[j] / a[i];dfs(usd + , tp + );
} vis[j] = ;
}
vis[i] = ;
}
}
int main(){
char s[][];
while(~scanf("%s %s %s %s",s[],s[],s[],s[])){
for(int i =;i < ;i++){
if(strlen(s[i]) == )a[i] = ;
else if(s[i][] == 'A')a[i] = ;
else if(s[i][] == 'J')a[i] = ;
else if(s[i][] == 'Q')a[i] = ;
else if(s[i][] == 'K')a[i] = ;
else a[i] = s[i][] - '';
}
ans = ;
memset(vis, , sizeof(vis));
dfs(, );
if(ans)
puts("Yes");
else
puts("No");
}
return ;
}

24点游戏&&速算24点(dfs)的更多相关文章

  1. hdu 1427 速算24点

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1427 速算24点 Description 速算24点相信绝大多数人都玩过.就是随机给你四张牌,包括A( ...

  2. hdu 1427 速算24点 dfs暴力搜索

    速算24点 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Problem De ...

  3. HDU 1427 速算24点【数值型DFS】

    速算24点 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  4. Hdu1427 速算24点 2017-01-18 17:26 46人阅读 评论(0) 收藏

    速算24点 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submiss ...

  5. HDU 1427 速算24点 (深搜)

    题目链接 Problem Description 速算24点相信绝大多数人都玩过.就是随机给你四张牌,包括A(1),2,3,4,5,6,7,8,9,10,J(11),Q(12),K(13).要求只用' ...

  6. hdu1427之速算24点

    速算24点 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  7. hdu 1427 速算24点【暴力枚举】

    速算24点 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  8. HDOJ 1427(dfs) 速算24点

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1427 思路分析: 题目要求判断是否存在一种运算组合使得4个数的计算结果为24,因为搜索的层次为3层,不 ...

  9. hdu1427 速算24点

    </pre><pre> //#pragma comment(linker, "/STACK:102400000,102400000") //HEAD #in ...

随机推荐

  1. VMware 虚拟机的网络连接方式详解

         VMWare提供了三种工作模式,它们是bridged(桥接模式).NAT(网络地址转换模式)和host-only(主机模式).要想在网络管理和维护中合理应用它们,你就应该先了解一下这三种工作 ...

  2. zabbix监控代理zabbix-proxy

    新公司监控用的zabbix,其中用到了zabbix-proxy,原先没有尝试弄过,现在先提前安装看看,以便后续使用查阅. Zabbix-proxy 是一个监控代理服务器,它收集监控到的数据,先存放在缓 ...

  3. 谈谈javascript的函数表达式及其应用

    我们都知道定义函数的方式有两种,一种是函数声明,另外一种就是函数表达式. 函数声明 语法为:function关键字后跟函数名.例如: function functionName(arg0) { //函 ...

  4. 浅谈postMessage多页面监听事件

    最近做了一个Echarts和Highcharts多图多页面连动的效果,就用到postMessage 如下介绍: 最开始在最外围的页面也就是所有页面的父级页面添加postMessage监听事件以便监听下 ...

  5. UVA 12125 March of the Penguins

    题意: 给定一些冰块,每个冰块上有一些企鹅,每个冰块有一个可以跳出的次数限制,每个冰块位于一个坐标,现在每个企鹅跳跃力为d,问所有企鹅能否跳到一点上,如果可以输出所有落脚冰块,如果没有方案就打印-1 ...

  6. Oracle数据类型与.NET中的对应关系(转)

    Oracle数据类型与.NET中的对应关系 2011-02-24 10:02:16 标签:C# oracletype Oracle 数据类型 .NET Oracle连接添加的引用不同,会存在数据类型不 ...

  7. hadoop压缩配置

    为何要使用压缩,压缩可以是文件的大小减小很多,节省空间:另外压缩后的文件在传输时更节省带宽. 所需软件: 1)lzo 2)hadoop-lzo 3)maven 安装编译: 1)lzo wget htt ...

  8. C++ 常见容器

    迭代器. 基本介绍(来源于网络):迭代器是一种抽象的概念.能够遍历容器内的 部分/全部 元素.每个迭代器中包含着元素的地址.  它可以将 抽象容器 和 泛型算法 结合起来.   大致原理: 1)迭代器 ...

  9. Android 部分机型GridView四周默认间距

    在测试兼容性时候,部分机型,比如联想和一加等手机,在使用Gridview的时候,会默认四周有默认边距,10dp左右. 这时候需要设置 android:listSelector="@andro ...

  10. 【ecos学习3】redboot on vmware 网络配置

    需要图形化编译的时候必须 Build->Packages 加入:Common ethernet support 才可以有网络功能 导入vmare需要修改网络连接模式: 1- 设置redbootI ...