总Time Limit: 
10000ms 
Memory Limit: 
65536kB

有一个奇妙的口袋。总的容积是40,用这个口袋能够变出一些物品,这些物品的整体积必须是40。John如今有n个想要得到的物品,每一个物品的体积各自是a1,a2……an。John能够从这些物品中选择一些,假设选出的物体的整体积是40,那么利用这个奇妙的口袋。John就能够得到这些物品。如今的问题是,John有多少种不同的选择物品的方式。
Input
输入的第一行是正整数n (1 <= n <= 20),表示不同的物品的数目。接下来的n行,每行有一个1到40之间的正整数。分别给出a1。a2……an的值。
Output
输出不同的选择物品的方式的数目。

Sample Input
3
20
20
20
Sample Output
3

这题非常经典,能够用非常多方法来做,我试了下面几种:

DFS:耗时0ms

#include <stdio.h>

int arr[22], ans, n, sum;

void DFS(int k)
{
if(sum >= 40){
if(sum == 40) ++ans;
return;
}
for(int i = k; i <= n; ++i){
sum += arr[i];
DFS(i + 1);
sum -= arr[i];
}
} int main()
{
int i;
scanf("%d", &n);
for(i = 1; i <= n; ++i)
scanf("%d", arr + i);
sum = ans = 0; DFS(1);
printf("%d\n", ans);
return 0;
}

普通递归:耗时60ms

#include <stdio.h>

int arr[22], n;

int getAns(int sum, int k)
{
if(sum == 0) return 1;
if(k == 0) return 0;
return getAns(sum, k - 1) + getAns(sum - arr[k], k - 1);
} int main()
{
int i;
scanf("%d", &n);
for(i = 1; i <= n; ++i)
scanf("%d", arr + i);
printf("%d\n", getAns(40, n));
return 0;
}

DP:耗时0ms

#include <stdio.h>

int arr[22], n, dp[42][22];
//dp[i][j]表示从前j种物品里配出价值i的方法数
int main()
{
int i, j;
scanf("%d", &n);
for(i = 1; i <= n; ++i){
scanf("%d", arr + i);
dp[0][i] = 1;
}
for(dp[0][0] = i = 1; i <= 40; ++i){
for(j = 1; j <= n; ++j){
dp[i][j] = dp[i][j - 1];
if(i - arr[j] >= 0) dp[i][j] += dp[i - arr[j]][j - 1];
}
}
printf("%d\n", dp[40][n]);
return 0;
}

递推型DP:耗时0ms

#include <stdio.h>

int n, sum[42];
//sum[i]表示价值能组成i的方法数
int main()
{
int i, j, temp;
scanf("%d", &n);
for(i = 0, sum[0] = 1; i < n; ++i){
scanf("%d", &temp);
for(j = 40; j; --j){
if(j + temp > 40) continue;
if(sum[j]) sum[j + temp] += sum[j];
}
++sum[temp];
}
printf("%d\n", sum[40]);
return 0;
}

百练2755 奇妙的口袋 【深搜】or【动规】or【普通递归】or【递推】的更多相关文章

  1. 百练2755:神奇的口袋(简单dp)

    描述有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40.John现在有n个想要得到的物品,每个物品的体积分别是a1,a2……an.John可以从这些物品中选择一些 ...

  2. NYOJ 10 skiing (深搜和动归)

    skiing 时间限制:3000 ms  |  内存限制:65535 KB 难度:5 描写叙述 Michael喜欢滑雪百这并不奇怪. 由于滑雪的确非常刺激.但是为了获得速度.滑的区域必须向下倾斜.并且 ...

  3. 深搜基础题目 杭电 HDU 1241

    HDU 1241 是深搜算法的入门题目,递归实现. 原题目传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1241 代码仅供参考,c++实现: #incl ...

  4. DFS-BFS(深搜广搜)原理及C++代码实现

    深搜和广搜是图很多算法的基础,很多图的算法都是从这两个算法中启发而来. 深搜简单地说就是直接一搜到底,然后再回溯,再一搜到底,一直如此循环到没有新的结点. 广搜简单地说就是一层一层的搜,像水的波纹一样 ...

  5. HDOJ/HDU 1015 Safecracker(深搜)

    Problem Description === Op tech briefing, 2002/11/02 06:42 CST === "The item is locked in a Kle ...

  6. [codevs1049]棋盘染色<迭代深搜>

    题目链接:http://codevs.cn/problem/1049/ 昨天的测试题里没有打出那可爱的迭代深搜,所以今天就来练一练. 这道题其实我看着有点懵,拿着题我就这状态↓ 然后我偷偷瞄了一眼hz ...

  7. C++ 深搜调错

    因为前两天某网站的比赛一个深搜错了,我只得了3等奖,我找不到错误,给别的大佬看他们又嫌恶心.emm……,比赛结束后我自己反思了一下,深搜写错了该怎么办,或者说怎样避免写错. 首先,变量名不要太ex,比 ...

  8. [深搜]C. 【例题3】虫食算

    C . [ 例 题 3 ] 虫 食 算 题目解析 正解 : Dfs + 剪枝 依题意,把样例以加法的形式展现出来. 根据加法的性质,可以得出有两种情况:有进位和没有进位的. 而从百位到最高位的结果,又 ...

  9. HDU--杭电--1195--Open the Lock--深搜--都用双向广搜,弱爆了,看题了没?语文没过关吧?暴力深搜难道我会害羞?

    这个题我看了,都是推荐的神马双向广搜,难道这个深搜你们都木有发现?还是特意留个机会给我装逼? Open the Lock Time Limit: 2000/1000 MS (Java/Others)  ...

随机推荐

  1. c - 计算1到20的阶乘

    #include <stdio.h> /* 题目:求 1+2!+3!+...+20!的和 */ unsigned long long int factorial(long n) { uns ...

  2. hibernate_validator_04

    对象图--个人觉得就是关联验证 ean Validation API不仅能够用来校验单个的实例对象,还能够用来校验完整的对象图.要使用这个功能,只需要在一个有关联关系的字段或者属性上标注 @Valid ...

  3. 使用Maven构建javaWeb项目时,启动tomcat出错:严重: Error configuring application listener of class org.springframework.web.context.ContextLoaderListener java.lang.ClassNotFoundException: org.springframework.web.conte

    在初学使用maven构建javaWeb的项目的时候,启动tomcat加载时,总是提示如下错误,辛苦一番终于找到解决办法. 严重: Error configuring application liste ...

  4. 重拾C++ 基础知识总结(一)

    1.使用gcc编译c++文件报错 proc1.cc:(.text+0x14): undefined reference to `std::cout' C++程序使用gcc命令只能编译,不能链接库文件 ...

  5. IOS快速开发之常量定义

    ---恢复内容开始--- 在IOS开发中,有一些方法常常需要用的,但是有很长的方法名,这造成了代码长,写起来累,我们可以通过宏定义了解决这些问题 比如说在代码布局的时候会遇上这样的问题,我们要获取上面 ...

  6. phpinfo.php

    ---恢复内容开始--- apache中的配置不对 查看httpd.conf文件中是否有: AddType ...... AddType application/x-httpd-php .php -- ...

  7. c# 重新认识 Double 浮点型

    double test1 = 0; for (int i = 0; i < 100000000; i++) { test1 += 0.0001; } 请问 test1 的值是几? 答案是:999 ...

  8. h.264 FMO

    在H.264之前的标准中,比如H.263,其比特流中的数据是按照一个宏块接一个宏块的方式排列的,一旦发生丢包,很多相邻宏块信息都会丢失,很难进行错误隐藏处理.在H.264中加入了一项新特性:把宏块在比 ...

  9. COJ 0885 LCS???

    LCS??? 难度级别:C: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 输入两个字符串A.B,输出他们的最长连续公共子串长度. 输入 第一 ...

  10. LeetCode——Longest Substring Without Repeating Characters

    Given a string, find the length of the longest substring without repeating characters. For example, ...