| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1668 人关注过本帖
标题:这题好难,能帮帮我吗?
只看楼主 加入收藏
根根本根
Rank: 2
来 自:上海
等 级:论坛游民
帖 子:64
专家分:15
注 册:2018-3-19
结帖率:62.5%
收藏
已结贴  问题点数:20 回复次数:8 
这题好难,能帮帮我吗?
输入四个数,输出24点所有解法,没有输出“none”
求代码
搜索更多相关主题的帖子: 输入 个数 输出 代码 
2018-03-19 22:22
殷玥
Rank: 2
等 级:论坛游民
帖 子:13
专家分:20
注 册:2018-3-20
收藏
得分:20 
没看懂,题目不详
2018-03-20 21:43
根根本根
Rank: 2
来 自:上海
等 级:论坛游民
帖 子:64
专家分:15
注 册:2018-3-19
收藏
得分:0 
回复 2楼 殷玥
好吧
2018-03-21 19:57
殷玥
Rank: 2
等 级:论坛游民
帖 子:13
专家分:20
注 册:2018-3-20
收藏
得分:0 
回复 3楼 根根本根
举个例子,输入什么,输出什么
2018-03-27 09:06
lt854633274
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2018-3-27
收藏
得分:0 
题目是什么
2018-03-27 23:58
根根本根
Rank: 2
来 自:上海
等 级:论坛游民
帖 子:64
专家分:15
注 册:2018-3-19
收藏
得分:0 
输入3 3 8 8
输出8/(3-8/3)=24
2018-03-29 21:35
根根本根
Rank: 2
来 自:上海
等 级:论坛游民
帖 子:64
专家分:15
注 册:2018-3-19
收藏
得分:0 
论坛生存法则:永远对帮助你的人保持礼貌,懂得感恩会获得更多的帮助。
2018-03-29 21:35
纯帅de肥猪
Rank: 2
等 级:论坛游民
威 望:3
帖 子:9
专家分:10
注 册:2016-3-4
收藏
得分:0 
24点算法,这个确实很难。
2018-04-24 11:22
dzy123
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:379
专家分:820
注 册:2013-4-18
收藏
得分:0 
程序代码:
#include <stdio.h>
#include <string.h>
#include <math.h>

#define LING    1E-6
#define CONT    4
#define VOLUE    24

float number[CONT];
char expression[CONT][20] ;
bool m_judge = false; //判断是否有解。
int count = 0;

void Find(int n)
{
int i = 0, j = 0;

if (n == 1)
{
if ( fabs(number[0] - 24) <= LING)
{
for (i = 0; i < 20; i++) 
{
printf("%c", expression[0][i]) ;
}
printf("\t\t") ;
m_judge = true;
count ++;
if((count % 2)==0) //使输出时每行三个表达式
printf("\n") ;
}
else
{ }
}
for(i = 0; i < n; i++)    //查找
{
for (j = i + 1; j < n; j++)    //与其后面的查找进行计算
{
float a, b;
char expressiona[20], expressionb[20];
a = number[i] ;
b = number[j] ;
number[j] = number[n - 1];

strcpy(expressiona, expression[i]) ;
strcpy(expressionb, expression[j]) ;
strcpy(expression[j], expression[n - 1]) ;
sprintf(expression[i], "(%s+%s)", expressiona, expressionb) ;
number[i] = a + b;
Find(n-1);
///////////////////////////////////
sprintf(expression[i], "(%s-%s)", expressiona, expressionb) ;
number[i] = a - b;
Find(n-1);
sprintf(expression[i], "(%s-%s)", expressionb, expressiona) ;
number[i] = b - a;
Find(n-1);
sprintf(expression[i], "(%s*%s)", expressiona, expressionb) ;
number[i] = a * b;
Find(n-1);
if (b != 0)
{
sprintf(expression[i], "(%s/%s)", expressiona, expressionb) ;
number[i] = a / b;
Find(n-1);
}
if (a != 0)
{
sprintf(expression[i], "(%s/%s)", expressionb, expressiona) ;
number[i] = b / a;
Find(n-1);
}
number[i] = a;    // 最后一层的Find(2)调用完成后将a重新赋值给number[i]即number[0]
number[j] = b;    // 最后一层的Find(2)调用完成后将b重新赋值给nubmer[j]即number[1]
strcpy(expression[i], expressiona) ;
strcpy(expression[j], expressionb) ;
}
}
}
int main()
{
int i, j ;
printf("请输入四个数:\n") ;
for (i = 0; i < CONT; i++)
{
char ch[20], s;
int a ;
printf("第%d个数:", i+1) ;
scanf("%f", &number[i]) ;
a = (int)number[i] ;
s = char(a + 48);
ch[0] = s ;
for (j = 1; j < 20; j++) 
{
ch[j] = 0 ;
}
strcpy(expression[i], ch) ;
}
printf("\n") ;
Find(CONT) ;
if(m_judge==true)
{
printf("\n\n成功!\n") ;
printf("总共的计算方法共有:%d\n", count) ;
}
else
{
printf("失败!") ;
}
return 0;
}
给你个c语言的vc6通过
2018-04-26 11:52
快速回复:这题好难,能帮帮我吗?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017519 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved