传送门

官方题解:http://acdream.info/topic?tid=4246

参考:https://www.cnblogs.com/nowandforever/p/4492428.html

题意:在给定的n个数中,能否找到几个数使得这几个和等于H;

思路:注意这道题的条件 0<n<=40, 0<=H<10^9, 0<=a[i]<10^9,其中 H 和 A [i] 给的比较大,dp的空间开不下,而n比较小,只有40,所以可以把所给的数分成20、20两部分,用dfs或者直接状态压缩从0至2^(n/2)循环来搞出每组所有可能的和(dfs+剪枝应该比循环快),然后再在第二部分找(H-第一部分的可能和)就可以了。卡了一下map和set。可以用hash或者二分来找

ac代码(600+ms):

#include <cstdio>
#include <algorithm>
using namespace std; const int maxn = ; //比2的20次大一点 int n,h,a[],d[],c[maxn],cnt,flag; int check(int s)
{
int le=,ri=cnt;
while(le<=ri)
{
int mid=(le+ri)>>;
if(c[mid]==s)return ;
if(c[mid]>s)
ri = mid - ;
else le = mid + ;
}
return ;
} void dfs(int sum,int cur,int nn,int on)//利用on使得两次dfs放在了一起
{
if(flag)return;
if(cur==nn+)
{
if(on)
c[++cnt]=sum;
else flag = check(h-sum);
return;
}
for(int i=;i<;i++)
{
int t=sum+d[cur]*i;
if(t > h)return;
dfs(t,cur+,nn,on);
}
}
int main(){
//freopen("in","r",stdin);
while(~scanf("%d%d",&n,&h))
{
for(int i = ; i <= n; i++)
{
scanf("%d",&a[i]);
}
cnt = flag = ;
int n1 = (n>>), n2=n-n1;//(n>>1)没加括号WA了几次
for(int i=; i<=n1; i++)
{
d[i]=a[i];
}
dfs(,,n1,); //第一次先算出前一半的所有可能和;
sort(c+,c+cnt+);
for(int i=n1+;i<=n;i++)
{
d[i-n1]=a[i];
}
dfs(,,n2,); //第二次求后一半的和 ,在用二分在前一半中找有没有对应的值
if(flag)puts("Yes");
else puts("No");
} return ;
}

我一开始注意到n比较小,就直接dfs暴力,但是超时了;

不过,我又看到有人没有用二分,只用了dfs+前缀和,0ms;

自己写的(12+ms)

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn = ;
int h,a[maxn],sum[maxn],n,ans=;
void dfs(int cur,int s)
{
if(ans)return;
if(s>sum[cur])return;
if(sum[cur]==s||s==){ans=;return;} for(int i=n;i>=;i--)
{
if(ans)return;
if(a[i]<=s)
{
dfs(i-,s-a[i]);
}
}
}
int main(){
// freopen("in","r",stdin);
while(~scanf("%d%d",&n,&h))
{
sum[]=;
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
}
sort(a+,a++n); //不sort一直超时
for(int i=;i<=n;i++)
{
sum[i]=sum[i-]+a[i];
}
ans=;
dfs(n,h);
if(ans)puts("Yes");
else puts("No");
} return ;
}

ACdream1726-A Math game+(DFS+二分)+(DFS+前缀和)的更多相关文章

  1. Codeforces Round #381 (Div. 2)D. Alyona and a tree(树+二分+dfs)

    D. Alyona and a tree Problem Description: Alyona has a tree with n vertices. The root of the tree is ...

  2. uva 10004 Bicoloring(dfs二分染色,和hdu 4751代码差不多)

    Description In the ``Four Color Map Theorem" was proven with the assistance of a computer. This ...

  3. Java实现 LeetCode 655 输出二叉树(DFS+二分)

    655. 输出二叉树 在一个 m*n 的二维字符串数组中输出二叉树,并遵守以下规则: 行数 m 应当等于给定二叉树的高度. 列数 n 应当总是奇数. 根节点的值(以字符串格式给出)应当放在可放置的第一 ...

  4. [BZOJ 1082] [SCOI2005] 栅栏 【二分 + DFS验证(有效剪枝)】

    题目链接:BZOJ - 1082 题目分析 二分 + DFS验证. 二分到一个 mid ,验证能否选 mid 个根木棍,显然要选最小的 mid 根. 使用 DFS 验证,因为贪心地想一下,要尽量先用提 ...

  5. Codeforces Round #299 (Div. 2)A B C 水 dfs 二分

    A. Tavas and Nafas time limit per test 1 second memory limit per test 256 megabytes input standard i ...

  6. 51nod1307(暴力树剖/二分&dfs/并查集)

    题目链接: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1307 题意: 中文题诶~ 思路: 解法1:暴力树剖 用一个数 ...

  7. Chapter2二分与前缀和

    Chapter 2 二分与前缀和 +++ 二分 套路 如果更新方式写的是R = mid, 则不用做任何处理,如果更新方式写的是L = mid,则需要在计算mid是加上1. 1.数的范围 789 #in ...

  8. ACdream 1726 A Math game (dfs+二分)

    http://acdream.info/problem?pid=1726 官方题解:http://acdream.info/topic?tid=4246 求n个数里面能不能选一些数出来让它们的和等于k ...

  9. 【BZOJ】1146: [CTSC2008]网络管理Network(树链剖分+线段树套平衡树+二分 / dfs序+树状数组+主席树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1146 第一种做法(时间太感人): 第二种做法(rank5,好开心) ================ ...

随机推荐

  1. Angular JS 中 指令详解

    Angular JS的强大功能就在于其可以自定义很多指令,现在就指令做一下详细的剖析. 一个Angular js 指令(directive)需要指定一个唯一的名字(myDirective)和一个函数, ...

  2. ue4使用SceneCapture2D创建小地图示例 蓝图

    做C++项目的时候遇到了一个小地图的问题,从网上找了个蓝图的思路,转载一下. 原文:https://www.engineworld.cn/thread-3835-1-1.html 本文使用ue4提供的 ...

  3. 自定义SWT控件四之其它下拉框

    4.其它下拉框 4.1 添加联动二级多选择框(有添加按钮和删除按钮) package com.view.control.select; import java.util.ArrayList; impo ...

  4. javascript+jQuery补充

    一.jQuery事件绑定 <div class='c1'> <div> <div class='title'>菜单一</div> <div cla ...

  5. 面向对象---prototype、__proto__、实例化对象三者之间的关系

    1.构造函数 a.什么是构造函数? 解释:通过关键字new 创建的函数叫做构造函数 作用:用来创建一个对象 废话少说直接上代码,首先我们还是创建一个构造函数人类 然后我们在创建两个实例,一个凡尘 一个 ...

  6. Python基础编程 内置函数

    内置函数 内置函数(一定记住并且精通) print()屏幕输出 int():pass str():pass bool():pass set(): pass list() 将一个可迭代对象转换成列表 t ...

  7. maven 打包并导出 lib 第三方jar

    一. maven 导出lib 包 执行命令 mvn dependency:copy-dependencies -DoutputDirectory=target/lib 或者在 eclipse 中执行, ...

  8. weblogic10.3.6漏洞修改方案

    1.CVE-2018-2628漏洞 CVE-2018-2628漏洞利用的第一步是与weblogic服务器开放在服务端口上的T3服务建立socket连接,可通过控制T3协议的访问来临时阻断攻击行为. W ...

  9. nginx负载均衡策略url_hash配置方法

    参考文章: https://docs.nginx.com/nginx/admin-guide/load-balancer/http-load-balancer/ 根据路径,进行一致性hash,具体的配 ...

  10. requestAnimationFrame 兼容方案

    [toc] 编写涉及:css, html, js 在线演示codepen html代码 <div class="roll-box"> <div class=&qu ...