速算24点(C++)

相信大家小时候都玩过算24点游戏

这段C++代码可以非常快速的算出所有可行解

在VS2013,VS2010下测试可运行

#include<cstdio>
#include<iostream>
#include <cmath>
using namespace std;
//+-*/   1234
unsigned long long int xx[1001];
int x=1;
int pd;
int f1(int a, int b, int c, int d)
{
	int sum;
	pd=0;
	char s1,s2,s3;
	for (int j = 1; j <= 4; j++)
	{
		for (int k = 1; k <= 4; k++)
		{
			for (int l = 1; l <= 4; l++)
			{
				sum = 0;
				sum += a;
				switch (j)
				{
				case 1:sum += b; break;
				case 2:sum -= b; break;
				case 3:sum *= b; break;
				case 4:
					{
						if (sum%b)
						{
							sum = 9999;
						}
						else
						{
							sum /= b;
						}
					}break;
				default:
					break;
				}
				switch (k)
				{
				case 1:sum += c; break;
				case 2:sum -= c; break;
				case 3:sum *= c; break;
				case 4:
					{
						if (sum%c)
						{
							sum = 9999;
						}
						else
						{
							sum /= c;
						}
					}break;
				default:
					break;
				}
				switch (l)
				{
				case 1:sum += d; break;
				case 2:sum -= d; break;
				case 3:sum *= d; break;
				case 4:
					{
						if (sum%d)
						{
							sum = 9999;
						}
						else
						{
							sum /= d;
						}
					}break;
				default:
					break;
				}
				switch (j)
				{
				case 1:s1='+';break;
				case 2:s1='-';break;
				case 3:s1='*';break;
				case 4:s1='/';break;
				}
				switch (k)
				{
				case 1:s2='+';break;
				case 2:s2='-';break;
				case 3:s2='*';break;
				case 4:s2='/';break;
				}
				switch (l)
				{
				case 1:s3='+';break;
				case 2:s3='-';break;
				case 3:s3='*';break;
				case 4:s3='/';break;
				}
				if (sum == 24)
				{
					if (x==0)
					{
						xx[x]=a*1000000+b*100000+c*10000+d*1000+j*100+k*10+l;
						x++;
						printf("((%d%c%d)%c%d)%c%d==24\n",a,s1,b,s2,c,s3,d);
					}
					else
					{
						for (int i=1;i<=x;i++)
						{
							if ((a*1000000+b*100000+c*10000+d*1000+j*100+k*10+l)==xx[i])
							{
								pd=1;
								break;
							}
						}
						if (pd==0)
						{
							xx[x]=a*1000000+b*100000+c*10000+d*1000+j*100+k*10+l;
							x++;
							printf("((%d%c%d)%c%d)%c%d==24\n",a,s1,b,s2,c,s3,d);
						}
					}
					return 1;
				}
			}
		}
	}
	return 0;
}
int f2(int a, int b, int c, int d)
{
	int sum = 0;
	sum = f1(a, b, c, d) + f1(a, b, d, c) + f1(a, c, b, d) + f1(a, c, d, b) + f1(a, d, b, c) + f1(a, d, c, b);
	if (sum != 0)
	{
		return 1;
	}
	else
	{
		return 0;
	}
}
int main()
{
	int a, b, c, d;
	int sum;
	cin >> a >> b >> c >> d;
	sum = f2(a, b, c, d) + f2(b, a, c, d) + f2(c, a, b, d) + f2(d, a, b, c);
	if (sum == 0)
	{
		cout << 'N' << endl;
	}
	return 0;
}


  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值