【a501】算24点
Time Limit: 1 second
Memory Limit: 32 MB
【问题描述】
几十年前全世界就浒一种数字游戏,至今仍有人乐此不疲。在中国我们把这种游戏称为“算24点”。您作为游戏者将得到4个1~9之间的自然数作为操作数,而你的任务是对这4个操作数进行适当的算术运算,要求运算结果等于24。
你可以使用的运算只有:+、-、*、/,你还可以使用()来改变运算顺序。注意:所有的中间结果必须是整数,所以一些除法运算是不允许的(如,(2*2)/4是合法的,2*(2/4)是不合法的)。下面给出一个游戏的具体例子:
若给出的4个操作数是:1、2、3、7,则一种可能的解答是1+2+3*7=24。
【输入格式】
仅有一行,四个1到9之间的自然数。
【输出格式】
如果有解的话,只要输出一个解,输出的是三行数据,分别表示运算的步骤。其中第一行是输入的两个数和一个运算符和运算后的结果,第二行是第一行的结果和一个输入的数据、运算符、运算后的结果;第三行是第二行的结果和输入的一个数、运算符和“=24”。如果两个操作数有大小的话则先输出大的。
如果没有解则输出“No answer!”
【输入样例】
1 2 3 7
【输出样例】
2+1=3
7*3=21
21+3=24
【题解】 搜索的策略是,这4个数字只进行三次运算。 我们只需要在搜索里加两个变量就可以了(int 当前算式的和,int 当前进行了几次运算) 然后加括号的问题,可以用全排列的方法解决。即把所有的数字和运算符的组合方式表示出来。然后看它 们的和是否为24. 运算次数==4的时候,判断一下和是否为24.如果是就输出。 注意在进行减法和除法之前。要先判断一下a是否大于b,如果不是,则需要调换顺序再减。注意不是看到 a<b就直接跳过了,而是更换一下它们的数字再减。这是个坑点。 【代码】#include <cstdio>
#include <stdlib.h> int a[5],num[4][2],ans[4];
bool bo[5];
char sym[4]; void input_data()
{
for (int i = 1;i <= 4;i++) //bo数组用来判断哪一些数字可以用,一开始全部可用
bo[i] = true;
for (int i = 1;i <= 4;i++) //输入4个数字
scanf("%d",&a[i]);
} void sear_ch(int now,int p) //当前算式的和为now,且进行到第p步运算
{
if (p > 3)
{
if (now == 24) //如果已经进行完3次运算 且和为24
{
for (int i = 1;i <= 3;i++) //输出3次运算的算式
{
int aa = num[i][0],bb = num[i][1];
if ( num[i][1] > num[i][0]) //大的靠前输出
a[0] = aa,aa = bb,bb = a[0];
printf("%d",aa);
putchar(sym[i]);
printf("%d=%d\n",bb,ans[i]); }
exit(0);
}
return;
}
for (int i = 1;i <= 4;i++) //找下一个可以用来运算的数字
if (bo[i])
{
int x = now,y = a[i]; //这是在做除法和减法的时候a < b的情况的特殊处理
if (x < y)
{
int t = x;
x = y;
y =t ;
} bo[i] = false; num[p][0] = x;
num[p][1] = y; //plus
sym[p] = '+'; //plus运算则不需要调换顺序
ans[p] = now+a[i]; //其实这里可以用x,y代替。这样最后就不用判断那一个大了。
sear_ch(now+a[i],p+1); //subtract
sym[p] = '-'; //subtract运算则需要 x > y,且一开始如果now < a[i]
//不能跳过,而要调换顺序然后再做减法
ans[p] = x-y;
sear_ch(x-y,p+1); //multiply
sym[p] = '*'; //multiply运算则不必管大小
ans[p] = now*a[i];
sear_ch(now*a[i],p+1); //division if (y != 0 && x % y == 0) //如果能够整除则可以除。因为有说不能出现分数。
{
sym[p] = '/';
ans[p] = x / y;
sear_ch(x/y,p+1);
} bo[i] = true;
}
} void get_ans()
{
for (int i = 1;i <= 4;i++) //全排列。
{
bo[i] = false;
sear_ch(a[i],1);
bo[i] = true;
}
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
input_data();
get_ans();
printf("No answer!"); //最后要记得输出无解信息。
return 0;
}
【a501】算24点的更多相关文章
- hdu 1427 速算24点
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1427 速算24点 Description 速算24点相信绝大多数人都玩过.就是随机给你四张牌,包括A( ...
- 24点游戏&&速算24点(dfs)
24点游戏 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...
- hdu1427之速算24点
速算24点 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Subm ...
- python实现算24的算法
1.介绍 给定4个整数,数字范围在1-13之间,任意使用 + - * / ( ) ,构造出一个表达式,使得最终结果为24,这就是常见的算24的游戏.本文介绍用Python语言实现的两种方式.2.实现思 ...
- python 穷举法 算24点(史上最简短代码)
本来想用回溯法实现 算24点.题目都拟好了,就是<python 回溯法 子集树模板 系列 -- 7.24点>.无奈想了一天,没有头绪.只好改用暴力穷举法. 思路说明 根据四个数,三个运算符 ...
- hdu 1427 速算24点 dfs暴力搜索
速算24点 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem De ...
- Hdu1427 速算24点 2017-01-18 17:26 46人阅读 评论(0) 收藏
速算24点 Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submiss ...
- HDU 1427 速算24点 (深搜)
题目链接 Problem Description 速算24点相信绝大多数人都玩过.就是随机给你四张牌,包括A(1),2,3,4,5,6,7,8,9,10,J(11),Q(12),K(13).要求只用' ...
- 【Nodejs】“快算24”扑克牌游戏算法 1.02
快算24是一种挺好的锻炼孩子算数能力的扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过有限四则运算得到结果24,四张牌必须仅用一次.各地玩法还有点差别,有的只算1-10,其它抽出来:有的地方把整幅牌都 ...
随机推荐
- 【2017中国大学生程序设计竞赛 - 网络选拔赛 && hdu 6154】CaoHaha's staff
[链接]点击打开链接 [题意] 给你一个面积,让你求围成这个面积最少需要几条边,其中边的连线只能是在坐标轴上边长为1的的线或者是两个边长为1 的线的对角线. [题解] 找规律题 考虑s[i]表示i条边 ...
- 使用Tomcat发布war包
第一步:下载tomacat 1.下载地址:http://tomcat.apache.org 2.解压后目录如下 3.双击bin文件夹下startup.bat 即可启动tomcat, 计算机会弹出控制台 ...
- t_user is not mapped [from t_user as u where u.loginname = :loginname and u.password =:password]
转自:https://blog.csdn.net/u010876380/article/details/52714539 错误: Struts Problem Report Struts has de ...
- 并发知识与concurrent包
要想进入一线互联网公司,这部分内容必须要会,否则的话,你始终都只能停留在比较low的段位. 关于并发知识,最重要的两个概念一定要搞清楚,那就是可见性和原子性.其中可见性与前面提到的volatile关键 ...
- PythonOOP面向对象编程3
override 函数重写 重写是在自定义的类内添加相应的方法,让自定义的类生成的对象(实例)像内建对象一样进行内建的函数操作 对象转字符串函数重写 repr(obj) 返回一个能代表此对象的表达式字 ...
- Loadrunner--关联详解
当录制脚本时,VuGen会拦截client端(浏览器)与server端(网站服务器)之间的对话,并且通通记录下来,产生脚本.在VuGen的Recording Log中,您可以找到浏览器与服务器之间所有 ...
- js进阶 12-14 jquery的事件触发函数是哪两个
js进阶 12-14 jquery的事件触发函数是哪两个 一.总结 一句话总结:trigger和triggerHandler 1.trigger传额外参数时候的注意事项是什么? 注意样例中是三个参数 ...
- 新浪sae上安装原生wordpress4.1
1. 加入/改动wp-config.php文件 <?php /** * WordPress 基础配置文件. * * 本文件包括下面配置选项: MySQL 设置.数据库表名前缀. * 密匙.Wor ...
- [Nuxt] Build a Vue.js Form then use Vuex Actions to Post to an API in Nuxt
The default behavior of submitting an HTML form is to reload the page. You can use the Vue.js @submi ...
- Android 最火高速开发框架AndroidAnnotations简单介绍
在上一篇Android 最火的高速开发框架androidannotations配置具体解释中介绍了在eclipse中配置androidannotation的步骤,如需配置请參考. 1.目标 andro ...