今天碰到了这个我问题~~以下两个算法都不是我写的,第一个C版本的,第二个是C++版本的~~
说实话我写不出来这个算法~~
哎~~看来我在算法这条路上还有很远的路要走啊~也许我连起码的入门都没开始呢~~
问题是:
24点游戏相信大家都玩过,不过我还是要啰嗦一下。
从一副纸牌中,任意抽出4张。然后对这四个数字使用加减乘除四种运算符号和括号进行运算,使其最终的结果是24。
必须精确运算,结果不能四舍五入到24。
例子如下
2 2 3 3
则
(2+2)*(3+3) = 24
程序要求,输入4个数字,之后输出相对应的计算式子。
#include
<stdio.h>
#include <stdlib.h>
#include <math.h>
char op[3],
o[5]="+-*/";
float n[4], on[10];
int used[4] = {0}, top=0, tp=0, x;
void chk(float k);
void search24(int d);
float calc(float n1, float n2, char o);
void make(int i, float p, float q, char o, int d);
int main( void )
{
printf("please input 4 card number:\n");
scanf("%f%f%f%f", &n[0], &n[1],
&n[2], &n[3]);
search24(0);
printf("No
answer.\n");
return 0;
}
void chk(float k)
{
if( (tp !=
3) || ( fabs(k-24.0) > 0.000001 ))
//没有用完3个运算符或者结果不为24就退出.
return;
for(x=0;
x<5;
x+=2)
//这样设计是为了使3个选中的符号都可以得到输出.
printf("%g%c%g=%g\n", on[x], op[x/2],
on[x+1],
//分析得到的.
calc(on[x], on[x+1], op[x/2]));
system("pause");
exit(0);
}
float calc(float n1, float n2, char o)
{
switch(o){
case '+': return (n1+n2);
case '-': return (n1-n2);
case '*': return (n1*n2);
case '/': return (n1/n2);
default: exit(0);
}
}
void make(int i, float p, float q, char o, int d)
{
if(fabs(q)>0.000001 ||
o!='/')
//除数不为0,或者为0的时候不能为除数.
n[i] = calc(p, q, o);
op[tp++] =
o;
chk(n[i]);
search24(d+1);
tp--;
//因为是全是全局变量,所以在做试验性的循环递归问题时,如果失败,要在递归函数后面重新恢复回原来的值
}
void search24(int d)
{
int i, j,
k;
float p,
q;
if(d>=3)
//控制递归深度,就是运算符的输出个数.
return;
for(i=0;
i<4; i++)
for(j=0; j<4; j++)
if( (i!=j)&& (used[i]+used[j] == 0)
) //i!=j是防止重复,(used[i]+used[j] == 0)是防止又再匹配已经用过的j,
//但是i可以新来.
{
used[j] = 1;
//j得到匹配之后,赋值为1,表示已经使用
p=n[i];
q=n[j];
on[top++] = p;
on[top++] =
q;
for(k=0; k<4; k++)
//运算符的循环试用.
make(i, p, q, o[k], d);
n[i] =
p;
//因为是全是全局变量,所以在做试验性的循环递归问题时,
used[j] =
0;
//如果失败,要在递归函数后面重新恢复回原来的值
top -=
2;
//
}
}
#include
<iostream>
#include
<string>
#include
<cmath>
using namespace
std;
const
double PRECISION =
1E-6;
const int
COUNT_OF_NUMBER =
4;
const int NUMBER_TO_BE_CAL =
24;
double
number[COUNT_OF_NUMBER];
string
expression[COUNT_OF_NUMBER];
bool Judgement =
false;
//判断是否有解。
int count =
0;
void
Search(int
n)
{
if (n
== 1)
{
if ( fabs(number[0] - NUMBER_TO_BE_CAL) <=
PRECISION )
//对于除法,要小心小数的精确位数
{
cout << expression[0]
<< "\t\t";
Judgement = true;
count ++;
if((count % 3)==0)
cout<<endl;
}
else
{
}
}
for(int i=0; i < n; i++)
{
for (int j = i + 1; j < n; j++)
{
double
a,
b;
string
expa,
expb;
a
=
number[i];