[haut] 1281: 邪能炸弹 dp
题目描述
输入
对于测试实例:
第一行为三个整数 n,begin,MAX。1<=n<=50,0<=begin<=MAX,1<=MAX<=1000。
第二行一次为n个整数 x1,x2,x3,x4...xn。1<=xi<=1000
输出
样例输入
- 2
- 3 5 10
- 5 3 7
- 3 3 8
- 5 2 10
样例输出
- 10
- -1
- 思路:当时的写的是dfs ac了 可以构造一颗搜索树 然后搜索就好了
题解是用的dp 设dp[i][j]为第i天时值为j的存在状态 1为存在 0为不存在 如果dp[i-1][j] = 1 那么可由此推出dp[i][j + Xi] 和 dp[i][j - Xi]的存在状态
若j在i-1和i阶段取值0~Max内都不存在的话 直接可以返回-1了
dfs:
- #include <iostream>
- #include <stdio.h>
- #include <queue>
- using namespace std;
- int a[];
- int n, b, Max;
- int ans;
- void dfs(int ret, int t)
- {
- if (ret < || ret > Max)
- return;
- if (t == n) {
- ans = max(ans, ret);
- return;
- }
- dfs(ret+a[t], t+);
- dfs(ret-a[t], t+);
- }
- int main()
- {
- //freopen("1.txt", "r", stdin);
- int T;
- scanf("%d", &T);
- while (T--) {
- ans = -;
- scanf("%d%d%d", &n, &b, &Max);
- for (int i = ; i < n; i++)
- scanf("%d", &a[i]);
- dfs(b, );
- printf("%d\n", ans);
- }
- return ;
- }
- dp:
- #include <iostream>
- #include <stdio.h>
- #include <cstring>
- #include <algorithm>
- using namespace std;
- int dp[][];
- int n, b, Max;
- int x[];
- int main()
- {
- //freopen("1.txt", "r", stdin);
- int T;
- scanf("%d", &T);
- while (T--) {
- scanf("%d%d%d", &n, &b, &Max);
- for (int i = ; i <= n; i++)
- scanf("%d", &x[i]);
- memset(dp, , sizeof(dp));
- dp[][b] = ;
- int flag;
- for (int i = ; i <= n; i++) {
- flag = ;
- for (int j = ; j <= Max; j++) {
- if (dp[i-][j]) {
- if (j + x[i] <= Max) {
- dp[i][j + x[i]] = ;
- flag = ;
- }
- if (j - x[i] >= ) {
- dp[i][j - x[i]] = ;
- flag = ;
- }
- }
- }
- if (flag == ) break;
- }
- int ans = -;
- for (int i = Max; i >= ; i--)
- if (dp[n][i]) {
- ans = i;
- break;
- }
- printf("%d\n", ans);
- }
- return ;
- }
[haut] 1281: 邪能炸弹 dp的更多相关文章
- 河南省多校联盟二-C
1281: 邪能炸弹 时间限制: 1 秒 内存限制: 128 MB提交: 222 解决: 80 题目描述 正在入侵艾泽拉斯的古尔丹偶然间得到了一颗邪能炸弹,经过研究,他发现这是一颗威力极其巨大且难 ...
- poj2228 Naptime【(环结构)线性DP】
Naptime Time Limit: 1000MS Memory Limit: 65536K Total Submissions:3374 Accepted: 1281 Descriptio ...
- HDU 5366 dp 递推
The mook jong Accepts: 506 Submissions: 1281 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65 ...
- 51nod 1281山峰和旗子
1281 山峰和旗子 题目来源: Codility 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 用一个长度为N的整数数组A,描述山峰和山谷的高度.山峰需要满足 ...
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
随机推荐
- 编译PHP扩展的通用方法
以安装swoole扩展为例: 步骤1: wget pecl.php.net/get/swoole-1.7.21.tgz (下载swoole打包文件) 步骤2: tar zxvf swoole-1. ...
- Js基础之函数
定义函数:我们使用function标签来定义函数 使用函数:JavaScript函数定义完毕是不能自动执行的,需要我们调用或者事件触发,比如点击事件,鼠标事件,键盘事件等. 下面我们以点击事件为例,调 ...
- sleep 和 usleep的实现方法
一.sleep 和 usleep 1.不属于系统调用,是glibc 库函数实现的: 2.glibc函数库中通过调用内核的nanosleep实现的: 3.内核nanosleep通过调用 hrtimer_ ...
- Spring 自动注册及自动装配
Spring支持三种注册Bean及装配Bean的方式: 显式地在Java代码中注册及装配 显示地在Xml文件中注册及装配 隐式地装配,即自动注册及装配 这三种方式可以混合使用.选择哪种更多地是看个人品 ...
- Redis事务和watch
redis的事务 严格意义来讲,redis的事务和我们理解的传统数据库(如mysql)的事务是不一样的. redis中的事务定义 Redis中的事务(transaction)是一组命令的集合. 事务同 ...
- 杂项:UUID
ylbtech-杂项:UUID UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写,是一种软件建构的标准,亦为开放软件基金会组织在分布式计算环境领域的一部 ...
- bash姿势-没有管道符执行结果相同于管道符
听起来比较别口: 直接看代码: shell如下: [root@sevck_linux ~]# </etc/passwd grep root root:x:::root:/root:/bin/ba ...
- tar命令解压jdk.tar.gz包 报错 gzip: stdin: not in gzip format
转自:https://blog.csdn.net/LL_zhuo/article/details/44173355 遇到和这篇博文一样的问题了.用wget 从oracle官网下载jdk, http:/ ...
- UML在软件开发中各个阶段的作用和意义
经典的软件工程思想将软件开发分成5个阶段:需求分析,系统分析与设计,系统实现,测试及维护五个阶段. 之所以如此,是因为软件开发中饣含了物和人的因素,存在着很大的不确定性,这使得软件工程不可能像理想的, ...
- python操作excel的读写
1.下载xlrd和xlwt pip install xlwd pip install xlrd pip install xlutils 2.读写操作(已存在的excel) #-*- coding:ut ...