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 ...
随机推荐
- 在命令提示符下启动并使用JVM时,简单设置堆
公司电脑内存太小了,只有8G:或者说JVM默认启动占用内存太大了,同时启动多个服务内存就炸了. 比如: java -Xmx128m -Xms64m -Xmn32m -Xss16m -jar eurek ...
- python中使用Opencv进行人脸识别
上一节讲到人脸检测,现在讲一下人脸识别.具体是通过程序采集图像并进行训练,并且基于这些训练的图像对人脸进行动态识别. 人脸识别前所需要的人脸库可以通过两种方式获得:1.自己从视频获取图像 2.从人 ...
- Bioconductor的历史
---------------------------------------------------------------Bioconductor------------------------- ...
- dubbo hessian+dubbo协议
Dubbo缺省协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况 Hessian协议用于集成Hessian的服务,Hessian底层采 ...
- clipboard.js复制文字
A-固定内容: <script type="text/javascript" src="script/clipboard.min.js"></ ...
- Python3 bytes 函数
Python3 bytes 函数 Python3 内置函数 描述 bytes 函数返回一个新的 bytes 对象,该对象是一个 0 <= x < 256 区间内的整数不可变序列.它是 b ...
- Intellij IDEA使用Maven搭建spark开发环境(scala)
如何一步一步地在Intellij IDEA使用Maven搭建spark开发环境,并基于scala编写简单的spark中wordcount实例. 1.准备工作 首先需要在你电脑上安装jdk和scala以 ...
- Microsoft SQL Server, 错误:4064的解决方法 (转载)
SQL SERVER – Fix : Error: 4064 – Cannot open user default database. Login failed. Login failed for u ...
- swift - 画图 - 画矩形,虚线,圆和半圆
import UIKit class JYJYBouncedCouponsViewCellBgView: UIView { //一定要在这里设置 背景色, 不要再draw里面设置, override ...
- 解决安装Apache中出现checking for APR... no configure: error: APR not found. Please read the documentation的问题
Linux中安装Apache 编译出现问题: 解决办法: 1.下载所需要的软件包 wget http://archive.apache.org/dist/apr/apr-1.4.5.tar.gz wg ...