24 Point game

时间限制:3000 ms  |  内存限制:65535 KB
难度:5
描写叙述

There is a game which is called 24 Point game.

In this game , you will be given some numbers. Your task is to find an expression which have all the given numbers and the value of the expression should be 24 .The expression mustn't have any other operator except plus,minus,multiply,divide and the brackets.

e.g. If the numbers you are given is "3 3 8 8", you can give "8/(3-8/3)" as an answer. All the numbers should be used and the bracktes can be nested.

Your task in this problem is only to judge whether the given numbers can be used to find a expression whose value is the given number。

输入
The input has multicases and each case contains one line

The first line of the input is an non-negative integer C(C<=100),which indicates the number of the cases.

Each line has some integers,the first integer M(0<=M<=5) is the total number of the given numbers to consist the expression,the second integers N(0<=N<=100) is the number which the value of the expression should be.

Then,the followed M integer is the given numbers. All the given numbers is non-negative and less than 100
输出
For each test-cases,output "Yes" if there is an expression which fit all the demands,otherwise output "No" instead.
例子输入
2
4 24 3 3 8 8
3 24 8 3 3
例子输出
Yes
No
来源
经典改编
上传者
张云聪





感觉很经典的一道深搜题。

昨天下午自己起初给sum定义了一个初始值0。后来发现第二个測试用例不正确。

。那时候实在是不知道哪里错了

以至于昨天晚上做梦都梦到自己AC了这道题 哈哈

我自己认为自己的方法没有错。于是今天早上就百度搜搜,发现没人和我的思想一样....别人都说是编程之美这本书上的。

。但是我也没看过

他们的思想都是在一个长度为n的数组中找到随意两个数。然后求和,然后把和再插入数组中。同一时候n--。

直到n=1.

o(︶︿︶)o ,我就仅仅好关闭了百度。

看着自己的程序慢慢调试,而且输出每个可能的结果值。

。后来还真被我发现了。。

由于我初始的sum为0的缘故,

假设仅仅有一个元素5,本来该仅仅有一个结果的。。但是因为我的原因会出现0-5=-5,0+5=5,0*5=0。0/5=0。

。。。傻了傻了。。

于是就又改了下AC了 。。嘿嘿。看来我的梦还是挺灵验的。。

看代码吧:

#include <stdio.h>
#include <math.h>
#include <string.h>
int flag,n;
double a[10],aim;//double型的把 由于相除嘛 难免会造成精度损失
int vis[10];
void dfs(double sum)
{
int cnt=0;
for(int i=0;i<n;i++)
if(vis[i])
cnt++;
if(cnt==n&&fabs(sum-aim)<0.0000001)//一个推断的条件。 当全部元素都用上。 并且sum和aim相差非常小
{
flag=1;
return ;
}
for(int i=0;i<n;i++)
{
if(!vis[i]&&!flag)
{
vis[i]=1;
dfs(sum+a[i]);//
dfs(sum-a[i]);//
dfs(sum*a[i]);//
dfs(sum/a[i]);//
dfs(a[i]/sum);//
dfs(a[i]-sum);//对于这个数sum仅仅能有6种情况
vis[i]=0;
}
}
}
int main()
{
int ncase;
scanf("%d",&ncase);
while(ncase--)
{
scanf("%d %lf",&n,&aim);
for(int i=0;i<n;i++)
scanf("%lf",&a[i]);
flag=0;
for(int i=0;i<n;i++)//
{
memset(vis,0,sizeof(vis));
vis[i]=1;
if(!flag)
dfs(a[i]);//起初的sum不应该为0,应该是数组中的某一个数、、
}//起初我没有上面这个for循环,仅仅有一个dfs(0);华丽丽的wa...
if(flag)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}

update:在杭电上做了一道题  今天细致想了想 这道题我的做法始终还是有些欠缺。即使能在nyoj上A了。

所以读者自行取舍。我还是忽略了 比方1 13 5 9 我的程序是执行不出来的。由于我的程序在运算的时候一定要和当前的结果有关。

所以假设想学习新知识看我在杭电上的题解把点击打开链接这两道题一样。也当巩固一下知识。

最新文章

  1. css3中transition和animation的回调处理
  2. C#获取C++中修改过的float数组(指针),dll
  3. Code First is a bad name,这些年我们对Code First的理解都错了 !很震惊吧?
  4. SQL Server开启READ_COMMITTED_SNAPSHOT
  5. js完美解决IE6不支持position:fixed的bug
  6. C# 中请求数据方式
  7. jsp获取struts2查询到的数据
  8. selenium IDE &amp; Remote Control &amp; Webdriver
  9. xxx is not in the sudoers file.This incident will be reported.的解决方法
  10. Cannot connect to (local) sql server 2008
  11. (转载)WindowsXP上安装和运行神器SqlMap的步骤
  12. 同步的HTTP请求
  13. OrientDB入门(1)Getting Started
  14. HTML标签fieldset
  15. OI退役
  16. oracle 查询数据库的各种命令
  17. Web Driver 8中定位方法 ——基于python语言
  18. vue简单实例代码
  19. python 迭代多个对象
  20. 【转载】Win10系统怎么清空剪切板?Win10系统清空剪切板的方法

热门文章

  1. Canvas链式操作
  2. Python包和日志模块
  3. 2018天梯赛第一次训练题解和ac代码
  4. 九度oj 题目1171:C翻转
  5. 【转】学习设计模式之前你必须掌握的-看懂UML类图
  6. Android获取当前应用版本号
  7. iOS键盘高度的获取
  8. Welcome-to-Swift-18类型转换(Type Casting)
  9. [luoguP2336] [SCOI2012]喵星球上的点名(后缀数组 + 暴力)
  10. P2420 让我们异或吧 (树链剖分,异或前缀和)