社区
C语言
帖子详情
寻求一个24点的算法。
VisionCat
2003-06-18 05:32:13
我想寻求一个C++的24点的算法。
如果有源代码就更好了。
如果有注释,就太好了。
如果能有解释就,最好了。
谢谢
...全文
53
4
打赏
收藏
寻求一个24点的算法。
我想寻求一个C++的24点的算法。 如果有源代码就更好了。 如果有注释,就太好了。 如果能有解释就,最好了。 谢谢
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
4 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
pzytony
2003-06-29
打赏
举报
回复
/*在TC2.0下通过,基本实现了24点算法*/
#include<stdio.h>
#include <conio.h>
int enumerate(int ans);
char op[]={'+','-','*','/'};
char *model[]=
{
"((AxB)yC)zD",
"(Ay(BxC))zD",
"Az(By(CxD))",
"Az((BxC)yD)",
"(AxB)z(CyD)"
};
int *A, *B, *C, *D;
char *x, *y ,*z;
int ***opd;
char ***opr;
char *sample;
int **oprand[]={&A,&B,&C,&D};
char **oprator[]={&x,&y,&z};
int a[4];
int main(void)
{
int i;
printf("Enter %d numbers.\n",4);
for(i=0;i<sizeof a/sizeof a[0];i++)
scanf("%d",a+i);
if(enumerate(24)==0)
printf("No solution!\n");
return 0;
}
int calculate()
{
int v1,v2;
char op;
if(*sample=='A'||*sample=='B'||*sample=='C'||*sample=='D')
v1=***opd++;
else if(*sample=='('){
sample++;
v1=calculate();
}
sample++;
while(*sample=='x'||*sample=='y'||*sample=='z'){
op=***opr++;
sample++;
if(*sample=='A'||*sample=='B'||*sample=='C'||*sample=='D')
v2=***opd++;
else if(*sample=='('){
sample++;
v2=calculate();
}
sample++;
//clrscr();
switch(op)
{
case '+': v1+=v2; break;
case '-' : if(v1<v2) return -1000;
else v1-=v2;break;
case '*': v1*=v2; break;
case '/': if(v2==0||v1%v2!=0)
return -1000;
else v1/=v2; break;
}
}
return v1;
}
int enumerate(int ans)
{
int k;
for(A=a;A<a+4;A++)
for(B=a;B<a+4;B++){
if(B==A) continue;
for(C=a;C<a+4;C++){
if(C==A||C==B)
continue;
D=a+6-(A-a)-(B-a)-(C-a);
for(x=op;x<op+4;x++)
for(y=op;y<op+4;y++)
for(z=op;z<op+4;z++)
for(k=0;k<5;k++){
opd=oprand;
opr=oprator;
sample=model[k];
if(calculate()==ans)
{
opd=oprand;
opr=oprator;
sample=model[k];
while(*sample){
switch(*sample)
{
case 'A':
case 'B':
case 'C':
case 'D':printf("%d",***opd++); break;
case 'x':
case 'y':
case 'z':printf("%c",***opr++);break;
case '(':
case ')':printf("%c",*sample);break;
}
*sample++;
}
printf("=24\n\n");
return 1;
}
}
}
}
return 0;
}
smartashuai
2003-06-18
打赏
举报
回复
我不认为哦,这应该是刚学C++的,学会运用一些算法是很好的!
去看http://expert.csdn.net/Expert/TopicView1.asp?id=1915536
我在里面说了很多了。
希望你能自己想想,不要让我再给出全部代码了!
祝好运!
Schlemiel
2003-06-18
打赏
举报
回复
用Python用Python,用C++做这种东西简直就是无聊。
boyfling
2003-06-18
打赏
举报
回复
如果分可以再多一些就太好了,呵呵呵呵
数据结构+
算法
综合资料库
在这个"数据结构+
算法
综合资料库"中,包含的CHM文件详细阐述了这些关键概念,旨在帮助初学者逐步提升到高级水平。 数据结构是组织和管理数据的方式,它允许我们有效地存储、检索和操作数据。常见的数据结构包括数组...
Java 45款 游戏源代码
这份"Java 45款 游戏源代码"的压缩包包含了一系列经典和有趣的Java游戏,对于学习Java编程、游戏开发或者
寻求
灵感的开发者来说,是
一个
极其宝贵的资源库。 首先,让我们逐一探讨这些游戏类型及其相关的编程知识点:...
Android 智能问答机器人的实现
4. **问答模型**:可以是
一个
简单的关键词匹配规则,或者是
一个
训练好的机器学习模型,用于理解和回答问题。 5. **数据存储与检索**:可能包含
一个
本地数据库或API接口,用于存储和检索问题与答案的配对。 6. **结果...
phpbb论坛2.03-2.04升级文件
本次压缩包中的"phpbb论坛2.03-2.04升级文件"是针对PHPBB论坛从2.03版本升级到2.04版本的重要工具,这对于维护和扩展你的论坛社区来说是
一个
关键步骤。以下是详细的升级知识点: 1. **背景和原因** - PHPBB 2.03...
迭代最近点
算法
流程详解(ICP
算法
)
它的目的是
寻求
点集之间的匹配关系,求解的结果是两点集之间的平移及旋转量。假设M、P是两个点集,P为待配准点集,M为基准数据点集(可以理解为两个不同坐标系中的点集),其基本原理如下: 1、搜索最近点:取P中...
C语言
70,040
社区成员
243,246
社区内容
发帖
与我相关
我的任务
C语言
C语言相关问题讨论
复制链接
扫一扫
分享
社区描述
C语言相关问题讨论
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章