随意输入4个数字判断是否可以凑成24,若可以打印出公式。
#include<iostream>
#include<string>
using namespace std;
string oper = "+-*/";
double calculate(double a,double b,int m)
{
switch(m)
{
case 1:return a+b;
case 2:return a-b;
case 3:return a*b;
case 4:return a/b;
}
}
bool case1(int a,int b,int c,int d,int m1,int m2,int m3)
{
double s1,s2,s3;
s1=calculate(a,b,m1);
s2=calculate(s1,c,m2);
s3=calculate(s2,d,m3);
if(s3==24)
{
cout<<"((("<<a<<oper[m1-1]<<b<<")"<<oper[m2-1]<<c<<")"<<oper[m3-1]<<d<<")=24"<<endl;
return true;
}
return false;
}
bool case2(int a,int b,int c,int d,int m1,int m2,int m3)
{
double s1,s2,s3;
s1=calculate(a,b,m1);
s2=calculate(c,d,m3);
s3=calculate(s1,s2,m2);
if(s3==24)
{
cout<<"(("<<a<<oper[m1-1]<<b<<")"<<oper[m2-1]<<"("<<c<<oper[m3-1]<<d<<"))=24"<<endl;
return true;
}
return false;
}
bool case3(int a,int b,int c,int d,int m1,int m2,int m3)
{
double s1,s2,s3;
s1=calculate(b,c,m1);
s2=calculate(a,s1,m2);
s3=calculate(s2,d,m3);
if(s3==24)
{
cout<<"(("<<a<<oper[m2-1]<<"("<<b<<oper[m1-1]<<c<<"))"<<oper[m3-1]<<d<<")=24"<<endl;
return true;
}
return false;
}
bool case4(int a,int b,int c,int d,int m1,int m2,int m3)
{
double s1,s2,s3;
s1=calculate(b,c,m1);
s2=calculate(s1,d,m2);
s3=calculate(a,s2,m3);
if(s3==24)
{
cout<<"("<<a<<oper[m1-1]<<"(("<<b<<oper[m1-1]<<c<<")"<<oper[m2-1]<<d<<"))=24"<<endl;
return true;
}
return false;
}
bool case5(int a,int b,int c,int d,int m1,int m2,int m3)
{
double s1,s2,s3;
s1=calculate(c,d,m1);
s2=calculate(b,s1,m2);
s3=calculate(a,s2,m3);
if(s3==24)
{
cout<<"("<<a<<oper[m3-1]<<"("<<b<<oper[m2-1]<<"("<<c<<oper[m1-1]<<d<<")))=24"<<endl;
return true;
}
return false;
}
bool Allcase(int a,int b,int c,int d)
{
int i,j,k;
for(i=1;i<=4;i++)
for(j=1;j<=4;j++)
for(k=1;k<=4;k++)
if(case1(a,b,c,d,i,j,k)==true||case2(a,b,c,d,i,j,k)==true||case3(a,b,c,d,i,j,k)==true||case4(a,b,c,d,i,j,k)==true||case5(a,b,c,d,i,j,k)==true)
{
return true;
}
return false;
}
bool judge(int a,int b,int c,int d)
{
int i,all[24][4]={ {a,b,c,d},{a,b,d,c},{a,c,b,d},{a,c,d,b},{a,d,b,c},{a,d,c,b},
{b,a,c,d},{b,a,d,c},{b,c,a,d},{b,c,d,a},{b,d,a,c},{b,d,c,a},
{c,a,b,d},{c,a,d,b},{c,b,a,d},{c,b,d,a},{c,d,a,b},{c,d,b,a},
{d,a,b,d},{d,a,d,b},{d,b,a,c},{d,b,c,a},{d,c,a,b},{d,c,b,a}
};
for(i=0;i<24;i++)
{
if(Allcase(all[i][0],all[i][1],all[i][2],all[i][3]))
return 1;
}
return 0;
}
int main()
{
int a,b,c,d;
cin>>a>>b>>c>>d;
if(judge(a,b,c,d)==0)
cout<<"你输入的数字不能凑成组成24点"<<endl;
}