Hdu1427 速算24点 2017-01-18 17:26 46人阅读 评论(0) 收藏
速算24点
Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other)
Total Submission(s) : 34 Accepted Submission(s) : 18
Font: Times New Roman | Verdana | Georgia
Font Size: ← →
Problem Description
Input
Output
Sample Input
A 2 3 6
3 3 8 8
Sample Output
Yes
No
4个数通过 +,—,*,/和加括号,计算得24,
枚举数字和运算符,DFS即可,注意题目要求计算过程中都不能出现小数,所以做除法时稍作处理
枚举数组可用algorithm里的next_permutation
#include <iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<queue>
#include<cstring>
#include<cstdlib>
using namespace std;
const int INF=9999999;
int a[10],p[10]; int jisuan(int a,int b,int x)
{
if(x==0)
return a+b;
if(x==1)
return a-b;
if(x==2)
return a*b;
if(x==3)
{
if(b==0)
return INF;
if(a%b!=0)
return INF;
return a/b;
}
} int dfs()
{
for(p[0]=0; p[0]<4; p[0]++)
for(p[1]=0; p[1]<4; p[1]++)
for(p[2]=0; p[2]<4; p[2]++)
{
int x1=0,x2=0,x3=0;
x1=jisuan(a[0],a[1],p[0]);
if(x1!=INF)x2=jisuan(x1,a[2],p[1]);
if(x2!=INF)x3=jisuan(x2,a[3],p[2]);
if(x1!=INF&&x2!=INF&&abs(x3)==24)
return 1; x1=0,x2=0,x3=0;
x1=jisuan(a[0],a[1],p[0]);
x2=jisuan(a[2],a[3],p[2]);
if(x1!=INF&&x2!=INF) x3=jisuan(x1,x2,p[1]);
if(x1!=INF&&x2!=INF&&abs(x3)==24)
return 1; }
return 0;
} int main()
{
char s[1000];
int k,cnt;
int ans;
while(gets(s)!=NULL)
{
cnt=0;
k=strlen(s);
for(int i=0; i<k; i++)
{
if(s[i]=='A')
a[cnt++]=1;
else if(s[i]>='2'&&s[i]<='9')
a[cnt++]=s[i]-'0';
else if(s[i]=='1')
{
a[cnt++]=10;
i++;
}
else if(s[i]=='J')
a[cnt++]=11;
else if(s[i]=='Q')
a[cnt++]=12;
else if(s[i]=='K')
a[cnt++]=13;
} sort(a,a+4);
do
{
ans=dfs();
if(ans)
break;
}
while (next_permutation(a,a+4));
if(ans)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}
Hdu1427 速算24点 2017-01-18 17:26 46人阅读 评论(0) 收藏的更多相关文章
- HDU 2042 不容易系列之二 [补6.24] 分类: ACM 2015-06-26 20:40 9人阅读 评论(0) 收藏
不容易系列之二 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Su ...
- Doubles 分类: POJ 2015-06-12 18:24 11人阅读 评论(0) 收藏
Doubles Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 19954 Accepted: 11536 Descrip ...
- Color Me Less 分类: POJ 2015-06-10 18:24 11人阅读 评论(0) 收藏
Color Me Less Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 31693 Accepted: 15424 D ...
- 【C#小知识】C#中一些易混淆概念总结(二)--------构造函数,this关键字,部分类,枚举 分类: C# 2014-02-03 01:24 1576人阅读 评论(0) 收藏
目录: [C#小知识]C#中一些易混淆概念总结--------数据类型存储位置,方法调用,out和ref参数的使用 继上篇对一些C#概念问题进行细节的剖析以后,收获颇多.以前,读书的时候,一句话一掠而 ...
- Lucene学习总结之四:Lucene索引过程分析 2014-06-25 14:18 884人阅读 评论(0) 收藏
对于Lucene的索引过程,除了将词(Term)写入倒排表并最终写入Lucene的索引文件外,还包括分词(Analyzer)和合并段(merge segments)的过程,本次不包括这两部分,将在以后 ...
- 全面解析sizeof(上) 分类: C/C++ StudyNotes 2015-06-15 10:18 188人阅读 评论(0) 收藏
以下代码使用平台是Windows7 64bits+VS2012. sizeof是C/C++中的一个操作符(operator),其作用就是返回一个对象或者类型所占的内存字节数,使用频繁,有必须对齐有个全 ...
- Struts知识问答 分类: 面试 2015-07-10 22:01 4人阅读 评论(0) 收藏
1. 简述Struts框架的初始化流程. 答案: 对于采用Struts框架的Web应用,在Web应用启动时就会加载并初始化控制器ActionServlet ActionServlet从struts-c ...
- 移植QT到ZedBoard(制作运行库镜像) 交叉编译 分类: ubuntu shell ZedBoard OpenCV 2014-11-08 18:49 219人阅读 评论(0) 收藏
制作运行库 由于ubuntu的Qt运行库在/usr/local/Trolltech/Qt-4.7.3/下,由makefile可以看到引用运行库是 INCPATH = -I/usr//mkspecs/d ...
- highgui.h备查 分类: C/C++ OpenCV 2014-11-08 18:11 292人阅读 评论(0) 收藏
/*M/////////////////////////////////////////////////////////////////////////////////////// // // IMP ...
随机推荐
- Haskell语言学习笔记(25)MonadState, State, StateT
MonadState 类型类 class Monad m => MonadState s m | m -> s where get :: m s get = state (\s -> ...
- (3)shiro自定义realm
上面一章说到shiro的认证和授权最底层就是调用realm的getAuthorizationInfo(获取用户的角色和资源)和getAuthenticationInfo(校验账号密码是否正确)两个方法 ...
- scala -- 传名参数
object Test{ def main(args: Array[String]): Unit = { def test(code : => Unit){// 传名参数 不计算函数值,而是把函 ...
- clusterProfiler包
1)enrichGO:(GO富集分析) 描述:GO Enrichment Analysis of a gene set. Given a vector of genes, this function ...
- quartz2.2.1 web配置
首先到http://www.quartz-scheduler.org/downloads/catalog下载工具包 将下载包中lib目录下的所有jar包导入到项目中 因为quartz依赖log4j,需 ...
- PIE结对项目编程
一.题目描述 构造程序并测试,分别是: 1.不能触发Fault. 2.触发Fault,但是不能触发Error. 3.触发Error,但是不能产生Failure. 二.结对对象 ...
- Python中类的定义与使用
目标: 1.类的定义 2.父类,子类定义,以及子类调用父类 3.类的组合使用 4.内置功能 1.类的定义 代码如下: #!/usr/bin/env python #coding:utf8 class ...
- centos7下mysql5.6的主从复制
一.mysql主从复制介绍 mysql的主从复制并不是数据库磁盘上的文件直接拷贝,而是通过逻辑的binlog日志复制到要同步的服务器本地,然后由本地的线程读取日志里面的sql语句,重新应用到mysql ...
- AdmBaseController 判断是否登录
代码 using Service.IService; using System; using System.Collections.Generic; using System.Linq; using ...
- css浮动的元素居中
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...