洛谷P1236 算24点
题目描述
几十年前全世界就流行一种数字游戏,至今仍有人乐此不疲.在中国我们把这种游戏称为“算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
说明
感谢chenyy提供special judge
DFS,每层枚举可用牌中的两张,枚举四种运算,符合条件(结果为正整数)就dfs到下一层运算,遇到算了3次凑到24点的情况就跳出函数,输出答案。
因为没看到结果为正整数,WA了四五次,悲伤。
搜索代码看着长,其实是基本相同的代码复制了四份2333
↑运算的部分为什么不写成函数?因为虽然这四种操作的代码结构一样,但是运算都有细微差别,就算写成函数,也得写四个特判,反而麻烦。不如写一个,复制四份,改一下每份的运算符号,粗暴但高效。(其实是为偷懒找借口)
/*by SilverN*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
using namespace std;
struct clc{
int a,b;
char c;
int res;
}ans[];
int a[];
int hd=,tl=;
int vis[];
bool dfs(int cnt,int dep){
if(dep>)return ;
int i,j,k;
for(i=;i<=cnt;i++)
if(vis[i])continue;
else
for(j=;j<=cnt;j++){
if(i==j)continue;
if(vis[j])continue;
//+
int tmp1=a[i],tmp2=a[j];
a[i]=a[i]+a[j];a[j]=;vis[j]=;
ans[tl++]=(clc){tmp1,tmp2,'+',a[i]};
if((a[i]== && tl==) || dfs(,dep+))return ;
tl--;vis[j]=;
a[i]=tmp1;a[j]=tmp2;
//- a[i]=a[i]-a[j];a[j]=;vis[j]=;
ans[tl++]=(clc){tmp1,tmp2,'-',a[i]};
if(a[i]>)//运算结果必须是正整数
if((a[i]== && tl==) || dfs(,dep+))return ;
tl--;vis[j]=;
a[i]=tmp1;a[j]=tmp2;
//*
a[i]=a[i]*a[j];a[j]=;vis[j]=;
ans[tl++]=(clc){tmp1,tmp2,'*',a[i]};
if((a[i]== && tl==) || dfs(,dep+))return ;
tl--;vis[j]=;
a[i]=tmp1;a[j]=tmp2;
// /
if(!a[j])continue;
if(a[i]%a[j]!=)continue;
a[i]=a[i]/a[j];a[j]=;vis[j]=;
ans[tl++]=(clc){tmp1,tmp2,'/',a[i]};
if((a[i]== && tl==) || dfs(,dep+))return ;
tl--;vis[j]=;
a[i]=tmp1;a[j]=tmp2;
}
return ;
}
int main(){
int i,j;
for(i=;i<=;i++) scanf("%d",&a[i]);
if(dfs(,)){
for(i=;i<tl;i++){
if(ans[i].c=='*' || ans[i].c=='+')
if(ans[i].a<ans[i].b)swap(ans[i].a,ans[i].b);
printf("%d%c%d=%d\n",ans[i].a,ans[i].c,ans[i].b,ans[i].res);
}
}
else printf("No answer!\n");
return ;
}
洛谷P1236 算24点的更多相关文章
- 洛谷 P1236 算24点
		
题目描述 几十年前全世界就流行一种数字游戏,至今仍有人乐此不疲.在中国我们把这种游戏称为"算24点".您作为游戏者将得到4个1~9之间的自然数作为操作数,而您的任务是对这4个操作数 ...
 - 题解 洛谷P1236 【算24点】
		
不得不说,个人认为许多大佬们把程序想复杂了,所以码量很长,但是实际上这题并不要这么复杂... 可以考虑用一个\(dfs\)维护一个状态\(f(n)[a_1,a_2--a_n]\) 接下来我们暴力枚举两 ...
 - P1236 算24点
		
#include <bits/stdc++.h> using namespace std; int b[4]; int a[3]; int calc(int a, int b, int c ...
 - [洛谷P3254] [网络流24题] 圆桌游戏
		
Description 假设有来自m 个不同单位的代表参加一次国际会议.每个单位的代表数分别为ri (i =1,2,--,m). 会议餐厅共有n 张餐桌,每张餐桌可容纳ci (i =1,2,--,n) ...
 - [洛谷P4012] [网络流24题] 深海机器人问题
		
Description 深海资源考察探险队的潜艇将到达深海的海底进行科学考察. 潜艇内有多个深海机器人.潜艇到达深海海底后,深海机器人将离开潜艇向预定目标移动. 深海机器人在移动中还必须沿途采集海底生 ...
 - 洛谷【P1236】算24点
		
我对状态空间的理解:https://www.cnblogs.com/AKMer/p/9622590.html 题目传送门:https://www.luogu.org/problemnew/show/P ...
 - 洛谷 P1957 口算练习题
		
洛谷 P1957 口算练习题 题目描述 王老师正在教简单算术运算.细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习. 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效 ...
 - 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题  有向无环图最小路径覆盖  最大流  二分图匹配  匈牙利算法
		
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...
 - 洛谷 P2763 试题库问题(网络流24题之一)
		
题目描述 «问题描述: 假设一个试题库中有n道试题.每道试题都标明了所属类别.同一道题可能有多个类别属性.现要从题库中抽取m 道题组成试卷.并要求试卷包含指定类型的试题.试设计一个满足要求的组卷算法. ...
 
随机推荐
- Tomcat:使用startup.bat启动tomcat遇到报错
			
问题:使用startup.bat启动tomcat的时候报错,按照网页上的办法都试了一遍,但是没有解决问题.命令窗口启动tomcat会一闪而过,然后退出. 解决:1 检查环境变量配置是否有问题: CAT ...
 - fei33423 工作 职场 格言
			
对老板: 1. 老板不知道你做的事情(目标设定) 2. 老板要的是规划(对上报告), 自己给自己设定 金字塔四位下的目标,各种维度.如何细化. 2.1 明确老板期望 2.2 与老板达成共识 2.3 ...
 - 【kmp】bzoj3620: 似乎在梦中见过的样子
			
考察kmp理解题 Description “Madoka,不要相信 QB!”伴随着 Homura 的失望地喊叫,Madoka 与 QB 签订了契约. 这是 Modoka 的一个噩梦,也同时是上个轮回中 ...
 - paper:synthesizable finit state machine design techniques using the new systemverilog 3.0 enhancements之enhanced coding styles
			
1.ANSI style 的代码比较紧凑. 下面规范推荐,比较好. 下面是带有parameter的module header的完整规范 一般1bit ,大家都是wire signal1 = gen_s ...
 - Manjaro 添加国内源和安装搜狗输入法
			
Manjaro 系统虽然比 Ubuntu 用着稳定,但有些小地方没有 Ubuntu 人性化,比如默认安装完的系统貌似没有中国的,Ubuntu 估计是用的人多,所以安装完后会根据所在地给你配置更新的源. ...
 - Python基础-面向对象初识--类
			
什么是类 具有相似功能和属性的一类实物 什么是对象 类的具体体现,具体到一个 面向对象的优势 1.类是一组相似功能的集合,使组织结构更加清晰和规范化 2.研究面向对象要有上帝的思维,用面向对象设计程序 ...
 - python3爬取墨迹天气并发送给微信好友,附源码
			
需求: 1. 爬取墨迹天气的信息,包括温湿度.风速.紫外线.限号情况,生活tips等信息 2. 输入需要查询的城市,自动爬取相应信息 3. 链接微信,发送给指定好友 思路比较清晰,主要分两块,一是爬虫 ...
 - STM32HAL学习博客
			
https://www.cnblogs.com/wt88/category/1297945.html
 - ACM 深度优化搜索算法小总结
			
深度优化搜索算法的本质:就是从一状态不断转移,如果无法转移了就需要返回上一个状态,知道找到解为止. 其核心:递归函数 基本模型: dfs(int i, int j) { //控制结束条件 //进行状态 ...
 - x200 xp 驱动下载
			
http://support.lenovo.com/en_US/downloads/detail.page?&LegacyDocID=MIGR-70602