24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 593  |  回复: 0

ju5200

木虫 (正式写手)

[求助] C++实现24点计算的代码哪位大哥能帮忙解释一下啊?课程设计,快急死了,万分感谢啊!

#include<iostream>
using namespace std;
#include<string>
#include<stdlib.h>
const double PRECISION = 1E-6; //精度常量
const int COUNT_OF_NUMBER = 4; //算24点的自然数个数
const int NUMBER_TO_BE_CAL = 24;
void Swap(int &m,int &n)
{
int x;
x=m;
m=n;
n=x;
}
class RationalNumber //定义有理数类(分子、分母)
{
protected:
int numerator,denominator; //numerator:分子,denominator:分母
bool inf;
protected:
int gcd(int a,int b) //求a和b的最大公约数
{
if(a==0)return b;if(b==0) return a;
if(a>b) Swap(a,b);
while(a>0){
int c=b%a;b=a;a=c;
}
return b;
}
public:
RationalNumber()
{
inf=false;
}
RationalNumber(int n)
{
numerator=n;
denominator=1;
inf=false;
}
RationalNumber(int numerator,int denominator)
{
this->numerator=numerator;
this->denominator=denominator;
Simplify();
}
virtual ~RationalNumber() {}
void Simplify()
{
if(denominator==0)
{
inf=true;
}
else
if(numerator==0)
{
denominator=1;
inf=false;
}
else
{
int k=gcd(abs(numerator),abs(denominator));
numerator/=k;
denominator/=k;
inf=false;
}
}

RationalNumber operator+(const RationalNumber& b) const
{
RationalNumber result;
result.denominator=this->denominator*b.denominator;
result.numerator=this->numerator*b.denominator+this->denominator*b.numerator;
result.Simplify();
return result;
}


RationalNumber operator-(const RationalNumber& b) const
{
RationalNumber result;
result.denominator=this->denominator*b.denominator;
result.numerator=this->numerator*b.denominator-this->denominator*b.numerator;
result.Simplify();
return result;
}


RationalNumber operator*(const RationalNumber& b) const
{
RationalNumber result;
result.denominator=this->denominator*b.denominator;
result.numerator=this->numerator*b.numerator;
result.Simplify();
return result;
}
RationalNumber operator/(const RationalNumber& b) const
{
RationalNumber result;
result.denominator=this->denominator*b.numerator;
result.numerator=this->numerator*b.denominator;
result.Simplify();
return result;
}
RationalNumber& operator=(const RationalNumber& b)
{
denominator=b.denominator;
numerator=b.numerator;
return (*this);
}
RationalNumber& operator=(int b)
{
denominator=1;
numerator=b;
return (*this);
}
bool operator==(const RationalNumber& b) const
{
if((b.denominator==this->denominator)&&(b.numerator==this->numerator)) return true;
return false;
}
bool operator==(int b) const
{
if((1==this->denominator)&&(b==this->numerator)) return true;
return false;
}
bool operator!=(const RationalNumber& b) const
{         if(b.denominator!=this->denominator||b.numerator!=this->numerator) return true;
return false;
}
bool operator!=(int b) const
{
if(1!=this->denominator||b!=this->numerator) return true;
return false;
}
int Numerator() const
{ return numerator; }
int Denominator() const
{ return denominator; }
};

RationalNumber number[COUNT_OF_NUMBER]; //用数组number[]保存操作数
string expression[COUNT_OF_NUMBER]; //用数组expression[]保存算式

bool Search(int n) //递归函数
{
if (n==1)
{
if (number[0]==NUMBER_TO_BE_CAL) //成功搜索得到24
//若number[]是double型
//也可用if (fabs(number[0]-NUMBER_TO_BE_CAL)<PRECISION)
{
cout<<expression[0]<<endl; //输出表达式
return true;
}
else
{
return false;
}
}
for (int i=0;i<n;i++)
{
for (int j=i+1;j<n;j++)
{
RationalNumber a, b;
string expa, expb;
a=number; //用a保存number
b=number[j]; //用b保存number[j]
number[j]=number[n-1]; //将number[n-1]向前填入到原来number[j]的位置
expa=expression; //用expa保存expression
expb=expression[j]; //用expb保存expression[j]
expression[j]=expression[n-1];
//将expression[n-1]向前填入到原来expression[j]的位置
//因为下一层递归调用search(n-1)将仅对下标为0~n-2的数进行操作了
//加法
expression='('+expa+'+'+expb+')';
//将a和b计算的算式填入到原来expression的位置
number=a+b; //将a和b计算的结果填入到原来number的位置
if (Search(n-1)) return true;
//一旦得到一个可行解,即层层向上返回,从而确保只输出一个可行解
//减法有两种情况a-b和b-a
expression='('+expa+'-'+expb+')';
number=a-b;
if (Search(n-1)) return true;
expression='('+expb+'-'+expa+')';
number=b-a;
if (Search(n-1)) return true;
//乘法
expression='('+expa+'*'+expb+')';
number=a*b;
if (Search(n-1)) return true;
//除法也有两种情况a/b和b/a
if (b!=0)
{
expression='('+expa+'/'+expb+')';
number=a/b;
if (Search(n-1)) return true;
}
if (a!=0)
{
expression='('+expb+'/'+expa+')';
number=b/a;
if (Search(n-1)) return true;
}
//本轮调用完毕后,用a,b,expa,expb将数组number[]和expression[]恢复原状
number=a;
number[j]=b;
expression=expa;
expression[j]=expb;
}
}
return false;
}





小弟的C++都是自学的  里面好多东西之前没接触过
因为课程设计时间比较紧 没时间查看相关资料
特来此求出 代码文件在附件里
稍微有点长 还请各位帮帮忙了
先谢谢各位了

int main()
{
cout<<"please input four numbers:"<<endl;
for (int i=0;i<COUNT_OF_NUMBER;i++)
{
char buffer[20]; //分配长度为20的字符数组buffer[]
int x;
cin>>x;
number=x;
itoa(x,buffer,10); //itoa():将一个10进制的integer数转换为string类型
//即:把输入的int型操作数x,转变成可以放在buffer[]中的string类型
expression=buffer; //用expression指针指向buffer[]数组空间的起始位置
}
bool dex=Search(4);
if(!dex) cout<<"Fail!!!"<<endl;

return 0;
}
回复此楼

» 猜你喜欢

» 本主题相关商家推荐: (我也要在这里推广)

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ju5200 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 302分初试 0854 +4 伶可乐 2026-04-02 4/200 2026-04-02 17:44 by chran16
[考研] 化工调剂303分,过四级 +9 栖梧待风 2026-04-02 9/450 2026-04-02 16:43 by SZW_UJN
[考研] 085801 总分275 本科新能源 求调剂 +16 bradoner 2026-04-01 20/1000 2026-04-02 15:27 by BruceLiu320
[考研] 08生物与医药专硕初试346找调剂 +6 dianeeee 2026-04-01 7/350 2026-04-02 08:23 by guoweigw
[考研] 085410 一志愿211 22408分数359求调剂 +3 123456789qw 2026-03-31 4/200 2026-04-02 00:06 by 义文wang
[考研] 266分,一志愿电气工程,本科材料,求材料专业调剂 +10 哇呼哼呼哼 2026-04-01 11/550 2026-04-01 21:48 by chyhaha
[考研] 材料调剂 +14 一样YWY 2026-04-01 14/700 2026-04-01 21:07 by lijunpoly
[考研] 286求调剂 +5 lim0922 2026-03-26 5/250 2026-04-01 19:08 by 客尔美德
[考研] 086502化学工程342求调剂 +7 阿姨复古不过 2026-03-27 7/350 2026-04-01 16:14 by yanflower7133
[考研] 283求调剂 +9 A child 2026-03-28 9/450 2026-04-01 14:20 by Jaylen.
[考研] 物理学调剂 +4 小羊36 2026-03-30 4/200 2026-03-31 16:16 by lishahe
[考研] 266分,求材料冶金能源化工等调剂 +8 哇呼哼呼哼 2026-03-27 10/500 2026-03-31 13:35 by Huaxue_Wang
[考研] 南京大学化学调剂 +11 景随风 2026-03-29 16/800 2026-03-31 10:14 by herarysara
[考研] 一志愿中海洋320化学工程与技术学硕求调剂 +8 披星河 2026-03-30 8/400 2026-03-31 08:53 by lbsjt
[考研] 08工科求调剂286 +5 tgs_001 2026-03-28 5/250 2026-03-31 08:18 by 一只好果子?
[考研] 085601一志愿西北工业大学初试346 +4 085601初试346 2026-03-30 4/200 2026-03-31 07:47 by jp9609
[有机交流] 甲基亚磺磺酸钠和甲基磺酸酯反应机理 10+3 kaobao456 2026-03-29 4/200 2026-03-30 23:16 by nBu锂
[考研] 0703 化学 求调剂,一志愿山东大学 342 分 +7 Shern—- 2026-03-28 7/350 2026-03-30 16:31 by nothing投稿中
[考研] 086000生物与医药调剂 +5 Feisty。 2026-03-28 9/450 2026-03-29 12:02 by longlotian
[考研] 285求调剂 +4 AZMK 2026-03-27 7/350 2026-03-27 20:59 by AZMK
信息提示
请填处理意见