bzoj1215 24点游戏
Description
为了培养小孩的计算能力,大人们经常给小孩玩这样的游戏:从1付扑克牌中任意抽出4张扑克,要小孩用“+”、“-”、“×”、“÷”和括号组成一个合法的表达式,并使表达式的值为24点。这种游戏就是所谓的“24点游戏”。请你编程求出对于给出的任意4个正整数a、b、c、d,请你编程求出这4个整数能组成多少个值为24的不同表达式。
Input
输入共一行,为4个正整数a、b、c、d (0<=a,b,c,d<=100)
Output
输出由a、b、c、d组成的值为24表达式个数,如没有,输出0。
两个不加多余括号的表达式相同当且仅当仅当完全相同或通过结合律可以互相转换
枚举可能的表达式,最多7680个,且要求表达式树中+或*的右子节点不为同优先级运算符
#include<cstdio>
#include<cmath>
#include<algorithm>
#define _0 0.000001
int v[],rnk[];
int hs[],p=,ans=;
inline void add(int v1,int v2,int v3,int v4,int v5,int v6,int v7){
hs[p++]=(v1|v2<<|v3<<|v4<<|v5<<|v6<<|v7<<);
}
inline double f(double a,double b,int op){
if(op==)return a+b;
if(op==)return a-b;
if(op==)return a*b;
return a/b;
}
inline bool e(int a,int b){
if(a==)return b>;
if(a==)return b<;
return ;
}
inline void chk(int v1,int v2,int v3,int v4){
for(int o1=;o1<;o1++){
for(int o2=;o2<;o2++){
for(int o3=;o3<;o3++){
bool e1=e(o3,o2),e2=e(o2,o1);
if(fabs(f(f(f(v[v1],v[v2],o1),v[v3],o2),v[v4],o3)-)<_0)add(rnk[v1],rnk[v2],o1+,rnk[v3],o2+,rnk[v4],o3+);
if(e1&&fabs(f(f(v[v1],v[v2],o1),f(v[v3],v[v4],o2),o3)-)<_0)add(rnk[v1],rnk[v2],o1+,rnk[v3],rnk[v4],o2+,o3+);
if(e2&&fabs(f(f(v[v1],f(v[v2],v[v3],o1),o2),v[v4],o3)-)<_0)add(rnk[v1],rnk[v2],rnk[v3],o1+,o2+,rnk[v4],o3+);
if(e1&&fabs(f(v[v1],f(f(v[v2],v[v3],o1),v[v4],o2),o3)-)<_0)add(rnk[v1],rnk[v2],rnk[v3],o1+,rnk[v4],o2+,o3+);
if(e1&&e2&&fabs(f(v[v1],f(v[v2],f(v[v3],v[v4],o1),o2),o3)-)<_0)add(rnk[v1],rnk[v2],rnk[v3],rnk[v4],o1+,o2+,o3+);
}
}
}
}
int main(){
for(int i=;i<;i++)scanf("%d",v+i);
for(int i=;i<;i++){
for(int j=;j<;j++)
if(i!=j)rnk[i]+=v[i]<v[j];
}
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
chk(,,,);
std::sort(hs,hs+p);
if(p)ans=;
for(int i=;i<p;i++)ans+=(hs[i]!=hs[i-]);
printf("%d",ans);
return ;
}
bzoj1215 24点游戏的更多相关文章
- 经典趣味24点游戏程序设计(python)
一.游戏玩法介绍: 24点游戏是儿时玩的主要益智类游戏之一,玩法为:从一副扑克中抽取4张牌,对4张牌使用加减乘除中的任何方法,使计算结果为24.例如,2,3,4,6,通过( ( ( 4 + 6 ) - ...
- cdoj 1252 24点游戏 dfs
24点游戏 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1252 Descr ...
- 24点游戏&&速算24点(dfs)
24点游戏 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...
- 24点游戏详细截图介绍以及原型、Alpha、Beta对比
原型设计 图片展示 功能与界面设计 1.登录注册 2.手机号验证 3.24点游戏 4.粉色系女生界面 Alpha 图片展示 功能与界面设计 1.24点游戏 2.背景音乐 3.可查看多种可能的答案 4. ...
- 【Nodejs】“快算24”扑克牌游戏算法
算24是一款扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过四则运算得到结果24,四张牌必须仅用一次.这是一种挺好的锻炼孩子算数能力的扑克牌游戏. 各地玩法还有点差别,有的只算1-10,其它抽出来:有 ...
- Leetcode 679.24点游戏
24点游戏 你有 4 张写有 1 到 9 数字的牌.你需要判断是否能通过 *,/,+,-,(,) 的运算得到 24. 示例 1: 输入: [4, 1, 8, 7] 输出: True 解释: (8-4) ...
- php实现 24点游戏算法
php实现 24点游戏算法 一.总结 一句话总结:把多元运算转化为两元运算,先从四个数中取出两个数进行运算,然后把运算结果和第三个数进行运算,再把结果与第四个数进行运算.在求表达式的过程中,最难处理的 ...
- Leetcode之深度优先搜索&回溯专题-679. 24 点游戏(24 Game)
Leetcode之深度优先搜索&回溯专题-679. 24 点游戏(24 Game) 深度优先搜索的解题详细介绍,点击 你有 4 张写有 1 到 9 数字的牌.你需要判断是否能通过 *,/,+, ...
- 用python代替人脑运算24点游戏
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:老方玩编程 PS:如有需要Python学习资料的小伙伴可以加点击下方链 ...
随机推荐
- POJ 1034 The dog task(二分图匹配)
http://poj.org/problem?id=1034 题意: 猎人和狗一起出去,狗的速度是猎人的两倍,给出猎人的路径坐标,除了这些坐标外,地图上还有一些有趣的点,而我们的狗,就是要尽量去多的有 ...
- shell 脚本sed替换文件中某个字符串
有些大文件,特别的大.有几百兆,甚至更大. 用文本编辑器打开十分的费劲,电脑都卡死了. 想替换其中的字符串,很麻烦. 这个时候有了shell,简直强大到爆炸! # du -h user.sql 304 ...
- Android------实现图片双击放大,缩小,左右滑动的多种方式
项目中常常有图片浏览功能.像微信朋友圈图片浏览,QQ空间照片浏览 的功能. 实现图片双击放大,缩小,左右滑动等效果. 来看看我的效果图,希望能满足你的要求 前三个button按钮是参考网上的多种实 ...
- Java开源-astar:A 星算法
astar A星算法Java实现 一.适用场景 在一张地图中,绘制从起点移动到终点的最优路径,地图中会有障碍物,必须绕开障碍物. 二.算法思路 1. 回溯法得到路径 (如果有路径)采用“结点与结点的父 ...
- torchnet package (1)
torchnet package (1) torchnet torchnet torchnet是用于torch的代码复用和模块化编程的框架,主要包含四个类 Dataset 以不同的方式对数据进行预处理 ...
- HDU1565 方格取数 &&uva 11270 轮廓线DP
方格取数(1) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- a标记无效问题
当在<a href=''></a>这个标记中嵌入<td></td> 就会导致部分浏览器无法单击,所以在开发HTML页面的时候,一定不要在 a标记中嵌入 ...
- 管道 && 消息队列 && 共享内存
http://blog.csdn.net/piaoairy219/article/details/17333691 1. 管道 管道的优点是不需要加锁. 缺点是默认缓冲区太小,只有4K. 一个管道只适 ...
- Hadoop的概念、版本、发展史
Hadoop是什么?Hadoop的起源Hadoop发展史Hadoop的四大特性(优点)Hadoop的版本如何选择Hadoop版本 Hadoop是什么? Hadoop: 适合大数据的分布式存储和计算平台 ...
- strtol 笔记
今天看了一下网上关于这个函数的解释,根据文章大意记录一下 strtol 是将字符串转换为long int的一个函数 strtol(const char* nptr, char **endptr, in ...