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 我的程序是执行不出来的。由于我的程序在运算的时候一定要和当前的结果有关。

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

nyoj43 24 Point game(DFS)的更多相关文章

  1. cdoj 1252 24点游戏 dfs

    24点游戏 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1252 Descr ...

  2. 24点游戏&&速算24点(dfs)

    24点游戏 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...

  3. DFS Used%: NaN%问题

    一.问题描述: [root@master sbin]# hdfs dfsadmin -report Configured Capacity: 0 (0 B) Present Capacity: 0 ( ...

  4. LeetCode Sum of Left Leaves

    原题链接在这里:https://leetcode.com/problems/sum-of-left-leaves/ 题目: Find the sum of all left leaves in a g ...

  5. Hadoop:搭建hadoop集群

    操作系统环境准备: 准备几台服务器(我这里是三台虚拟机): linux ubuntu 14.04 server x64(下载地址:http://releases.ubuntu.com/14.04.2/ ...

  6. Hadoop2.6.0完全分布式安装

    本文地址:http://www.cnblogs.com/myresearch/p/hadoop-full-distributed-operation.html,转载请注明源地址. 我这边是使用了两台主 ...

  7. Ubuntu_10.04下Hadoop-0.20.2集群配置手册

    Ubuntu_10.04下Hadoop-0.20.2集群配置手册 一.软硬件环境的准备 下面的文章来自hadoopor.com,我先交待一下我自己的环境: 两台机器,每台机器上面两个虚机(vmware ...

  8. hadoop默认3个核心配置文件说明

    1       获取默认配置 配置hadoop,主要是配置core-site.xml,hdfs-site.xml,mapred-site.xml三个配置文件,默认下来,这些配置文件都是空的,所以很难知 ...

  9. Hadoop2.3.0具体安装过程

    前言:       Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS.HDFS有高容错性的特点,并且设计用来部署在低廉的(low-co ...

随机推荐

  1. php isset()与empty()详解

    bool isset(mixed var);[;mixed var[,...]] 这个函数需要一个变量名称作为参数,如果这个变量存在,则返回true,否则返回false. 也可以传递一个由逗号间隔的变 ...

  2. PreResultListener

    PreResultListener是要给监听器接口,他可以在Action完成控制处理之后,系统转入实际的物理视图之间被回调. Struts 2 可以由ActionInvocation的addPreRe ...

  3. Spring 4.3.11.RELEASE文档阅读(二):Core Technologies_IOC

    在看这部分内容的时候,想了一些问题: 容器: 1,什么是容器 用来包装或装载物品的贮存器 2,容器能做什么 包装或装载物品 3,为什么需要容器 为什么要使用集装箱?如果没有容器会是什么样? 4,常见的 ...

  4. 九度oj 题目1370:数组中出现次数超过一半的数字

    题目描述: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2 ...

  5. 【CCF】商路

    [60分] #include<iostream> #include<cstdio> #include<cstring> #include<string> ...

  6. 如何在github上寻找漏洞

    https://github.com/search?p=2&q=eval%28%24_POST[&ref=searchresults&type=Code   1.$_GET s ...

  7. Censoring(bzoj 3940)

    Description Farmer John has purchased a subscription to Good Hooveskeeping magazine for his cows, so ...

  8. C语言第五题

    学生成绩管理系统 一.登录页面分为:首页展示学生登录和老师登录让用户选择,选择完以后提示用户输入账户名和密码 ps:1.老师的账户目前就一个,账户密码可以设置成admin/admin 2.学生的账户是 ...

  9. node总结--回调函数阻塞和非阻塞代码实例

    阻塞代码实例: var fs = require("fs"); var data = fs.readFileSync('input.txt'); console.log(data. ...

  10. class文件检查器

    Class文件检查器保证装载的class文件内容有正确的内部结构,并且这些class文件互相间协调一致.Class文件检查器实现的安全目标之一就是程序的健壮性.如果某个有漏洞的编译器,或某个聪明的黑客 ...