Power oj2470/DFS
题目链接 
 2469: C 小Y的难题(1) 
Time Limit: 1000 MS Memory Limit: 65536 KB 
Total Submit: 9 Accepted: 7 Page View: 128 
Submit Status Discuss 
Description
最近小Y迷上了数学,总是在思考各种数学问题。有一天,他不小心把墨水洒在草稿纸上。他现在能看到的是“2?3?1?4”(?表示看不清的地方)。小Y的记忆力不错,他知道: 
1、每个?只会是“+”、“-”,“=”三个符号之一。 
2、总共有且仅有一个“=”。 
3、原式一定是一个等式。如“2+3-1=4” 
现在他突然想知道,有多少种可能性,满足上面3个要求。 
Input
多组输入。 
每组第一行有一个数字n。表示小Y从左到右,一共可以看到n个数字。(2<=n<=15) 
每组第二行有n个数字。分别表示这n个数字是什么。保证每个数字都是非负整数,且小于10^7。 
Output
对于每组,输出一行,这一行只有一个数字,表示有多少种可能性满足题意。 
Sample Input 
Raw 
4 
2 3 1 4 
4 
1 1 1 1 
Sample Output 
Raw 
2 
6 
Hint
数字之间一定有且仅有一个符号,第一个数字前没有符号。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int a[25];
int n;
int ans=0;
void DFS(int sum,int num,int c)//num表示要处理的第几个数
{
    if(num==n)
    {
        if(sum==0)
            ans+=c;
        return ;
    }
    DFS(sum+a[num], num+1, c);
    DFS(sum-a[num], num+1,c+1);
}
int main ()
{
    while(~scanf("%d",&n))
    {
        for(int i=0;i<n;i++)
            scanf("%d",&a[i]);
        ans=0;
        DFS(a[0],1,0);
        printf("%d\n",ans);
    }
    return 0;
}
Power oj2470/DFS的更多相关文章
- UVA - 1374  Power Calculus (dfs迭代加深搜索)
		题目: 输入正整数n(1≤n≤1000),问最少需要几次乘除法可以从x得到xn ?在计算过程中x的指数应当总是正整数. 思路: dfs枚举次数深搜 注意: 1.指数如果小于0,就退出当前的搜索 2.n ... 
- UVa 1374 - Power Calculus——[迭代加深搜索、快速幂]
		解题思路: 这是一道以快速幂计算为原理的题,实际上也属于求最短路径的题目类型.那么我们可以以当前求出的幂的集合为状态,采用IDA*方法即可求解.问题的关键在于如何剪枝效率更高.笔者采用的剪枝方法是: ... 
- 深度优先搜索 DFS(Depath First Search, DFS)
		深度优先搜索是一种枚举所有完整路径以遍历所有情况的搜索方法.(不撞南墙不回头) DFS一般用递归来实现,其伪代码思路过程一般如下: void DFS(必要的参数){ if (符和遍历到一条完整路 ... 
- NOIP2016普及组复赛解题报告
		提高组萌新,DAY1DAY2加起来骗分不到300,写写普及组的题目聊以自慰. (附:洛谷题目链接 T1:https://www.luogu.org/problem/show?pid=1909 T2:h ... 
- POJ1185 状压dp(二进制//三进制)解法
		很显然这是一道状压dp的题目 由于每个最优子结构和前两行有关,一个显而易见的想法是用三维dp[i][j][k]用来记录在第i行下为j状态,i - 1行为k状态时的最大值,然而dp[100][1 < ... 
- [BJOI2017]树的难题 点分治 线段树
		题面 [BJOI2017]树的难题 题解 考虑点分治. 对于每个点,将所有边按照颜色排序. 那么只需要考虑如何合并2条链. 有2种情况. 合并路径的接口处2条路径颜色不同 合并路径的接口处2条路径颜色 ... 
- [sdoi2015]排序(搜索+剪枝优化)
		Description 小A有一个1-2^N的排列A[1..2^N],他希望将A数组从小到大排序,小A可以执行的操作有N种,每种操作最多可以执行一次,对于所有的i(1<=i<=N),第i中 ... 
- UVa 10294(polya 翻转与旋转)
		Arif in Dhaka(First Love Part 2) Input: standard input Output: standard output Time Limit: 2 seconds ... 
- poj 3134 Power Calculus(迭代加深dfs+强剪枝)
		Description Starting with x and repeatedly multiplying by x, we can compute x31 with thirty multipli ... 
随机推荐
- ActiveMQ in Action(2) - Transport
			关键字: activemq 2.2 Transport ActiveMQ目前支持的transport有:VM Transport.TCP Transport.SSL Transport.Peer ... 
- MVC3+EF4.1学习系列(四)----- ORM关系的处理
			上篇文章 终于把基础的一些操作写完了 但是这些都是单表的处理 而EF做为一个ORM框架 就必须点说说对于关系的处理 处理好关系 才能灵活的运用EF 关于关系的处理 一般就是 一对一 一对多 ... 
- jvm的可见性的理解
			同步包括两方面的含义: 独占性和可见性. 很多人仅仅理解了独占性,而忽略了可见性. 根据Java Language Specification中的说明, jvm系统中存在一个主内存(Main Memo ... 
- 34.编写2个接口:InterfaceA和InterfaceB;在接口InterfaceA中有个方法void printCapitalLetter();在接口InterfaceB中有个方法void printLowercaseLetter();然 后写一个类Print实现接口InterfaceA和InterfaceB,要求printCapitalLetter()方法 实现输出大写英文字母表的功能,
			//接口InterfaceA package jieKou; public interface IInterfaceA { void printCapitalLetter(); } //接口Inter ... 
- iOS中的触摸事件,手势识别,摇晃事件等
			在iOS中,事件可以划分为以下几类: 1.触摸事件:通过触摸,手势进行触发(手指点击.缩放等) 2.运动事件:通过加速器触发(例如手机晃动) 3.远程控制事件:通过其他远程设备触发(例如耳机控制按钮) ... 
- asp 操作 json
			<% Dim sc4Json Sub InitScriptControl Set sc4Json =Server.CreateObject("MSScriptControl.Scrip ... 
- perl版 Webshell存活检测
			原理: 检测url返回状态即可 源码: #!c:\\perl\\bin\\perl.exe use warnings; use strict; use LWP::UserAgent; $| = ; p ... 
- swift UILable的用法
- AutoTile 自动拼接 番外篇(自动融合技术)
			http://pan.baidu.com/s/1dDQyfSl 密码:ttud 先睹为快吧. 之后 还差一个 智能替换 技术. 
- web开发路径问题
			1. web开发路径问题总结: http://www.cnblogs.com/tianguook/archive/2012/08/31/2665755.html 2. JSP/SERVLET 路径问题 ... 
