蓝桥杯 算法训练 24点
题目描述
- 资源限制
时间限制:1.0s 内存限制:256.0MB
- 问题描述
24点游戏是一个非常有意思的游戏,很流行,玩法很简单:给你4张牌,每张牌上有数字(其中A代表1,J代表11,Q代表12,K代表13),你可以利用数学中的加、减、乘、除以及括号想办法得到24,例如:
((A*K)-J)*Q等价于((1*13)-11)*12=24
加减乘不用多说了,但除法必须满足能整除才能除!这样有一些是得不到24点的,所以这里只要求求出不超过24的最大值。
- 输入格式
输入第一行N(1<=N<=5)表示有N组测试数据。每组测试数据输入4行,每行一个整数(1到13)表示牌值。
- 输出格式
每组测试数据输出一个整数,表示所能得到的最大的不超过24的值。
- 样例输入
3
3
3
3
3
1
1
1
1
12
5
13
1
- 样例输出
24
4
21
方案1 暴力递归搜索
#include<iostream>
using namespace std;
int n;
int nums[4];
int ans;
void f(int nums[], int n){
if(n==1){
if(nums[n-1]<=24){
ans = ans<nums[n-1]?nums[n-1]:ans;
}
return ;
}
for(int i=0; i<n-1; i++){
for(int j=i+1; j<n; j++){
int a=nums[i], b=nums[j];
nums[j] = a + b;
nums[i] = nums[n-1];
f(nums, n-1);
nums[j] = a * b;
nums[i] = nums[n-1];
f(nums, n-1);
nums[j] = a - b;
nums[i] = nums[n-1];
f(nums, n-1);
nums[j] = b - a;
nums[i] = nums[n-1];
f(nums, n-1);
if(b!=0 && a%b==0){
nums[j] = a / b;
nums[i] = nums[n-1];
f(nums, n-1);
}
if(a!=0 && b%a==0){
nums[j] = b / a;
nums[i] = nums[n-1];
f(nums, n-1);
}
nums[i] = a;
nums[j] = b;
}
}
}
int main(){
cin>>n;
for(int i=0; i<n; i++){
for(int j=0; j<4; j++){
cin >> nums[j];
}
ans = 0;
f(nums, 4);
cout<<ans<<endl;
}
return 0;
}