ACdream1726-A Math game+(DFS+二分)+(DFS+前缀和)
官方题解: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+前缀和)的更多相关文章
- 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 ...
- uva 10004 Bicoloring(dfs二分染色,和hdu 4751代码差不多)
Description In the ``Four Color Map Theorem" was proven with the assistance of a computer. This ...
- Java实现 LeetCode 655 输出二叉树(DFS+二分)
655. 输出二叉树 在一个 m*n 的二维字符串数组中输出二叉树,并遵守以下规则: 行数 m 应当等于给定二叉树的高度. 列数 n 应当总是奇数. 根节点的值(以字符串格式给出)应当放在可放置的第一 ...
- [BZOJ 1082] [SCOI2005] 栅栏 【二分 + DFS验证(有效剪枝)】
题目链接:BZOJ - 1082 题目分析 二分 + DFS验证. 二分到一个 mid ,验证能否选 mid 个根木棍,显然要选最小的 mid 根. 使用 DFS 验证,因为贪心地想一下,要尽量先用提 ...
- 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 ...
- 51nod1307(暴力树剖/二分&dfs/并查集)
题目链接: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1307 题意: 中文题诶~ 思路: 解法1:暴力树剖 用一个数 ...
- Chapter2二分与前缀和
Chapter 2 二分与前缀和 +++ 二分 套路 如果更新方式写的是R = mid, 则不用做任何处理,如果更新方式写的是L = mid,则需要在计算mid是加上1. 1.数的范围 789 #in ...
- ACdream 1726 A Math game (dfs+二分)
http://acdream.info/problem?pid=1726 官方题解:http://acdream.info/topic?tid=4246 求n个数里面能不能选一些数出来让它们的和等于k ...
- 【BZOJ】1146: [CTSC2008]网络管理Network(树链剖分+线段树套平衡树+二分 / dfs序+树状数组+主席树)
http://www.lydsy.com/JudgeOnline/problem.php?id=1146 第一种做法(时间太感人): 第二种做法(rank5,好开心) ================ ...
随机推荐
- Android:JNI与NDK(二)交叉编译与动态库,静态库
欢迎关注公众号,第一时间获取最新文章: 本篇目录 一.前言 本篇主要以window开发环境为背景介绍一下NDK开发中需要掌握的交叉编译等基础知识,选window系统主要是照顾大多数读者,mac ,li ...
- XSS危害——session劫持(转载)
在跨站脚本攻击XSS中简单介绍了XSS的原理及一个利用XSS盗取存在cookie中用户名和密码的小例子,有些同学看了后会说这有什么大不了的,哪里有人会明文往cookie里存用户名和密码.今天我们就介绍 ...
- 使用阿里云对docker拉取镜像加速
使用docker的时候,总是需要去search镜像,使用国外的源下载太慢,还有诸多的限制,无意中发现可以使用阿里云进行加速,实测有用,废话少说,操作如下: 1.打开阿里云控制台,没有的可以用淘宝账号或 ...
- 【部分转载】:【lower_bound、upperbound讲解、二分查找、最长上升子序列(LIS)、最长下降子序列模版】
二分 lower_bound lower_bound()在一个区间内进行二分查找,返回第一个大于等于目标值的位置(地址) upper_bound upper_bound()与lower_bound() ...
- CMD开放3389端口
REG ADD HKLM\SYSTEM\CurrentControlSet\Control\Terminal" "Server /v fDenyTSConnections /t R ...
- Linux 下用C语言连接 sqlite
1.在 /home/ 新建一个文件夹名为 sqlite #cd /home #mkdir sqlite 2.编写C语言代码,名称为 sql.c,代码如下 // name: sql.c // This ...
- Android老司机搬砖小技巧
作为一名Android世界的搬运工,每天搬砖已经够苦够累了,走在坑坑洼洼的道路一不小心就掉坑里了. SDK常用工具类 Android SDK中本身就拥有很多轮子,熟悉这些轮子,可以提高我们的搬砖效率. ...
- node爬虫的几种简易实现方式
说到爬虫大家可能会觉得很NB的东西,可以爬小电影,羞羞图,没错就是这样的.在node爬虫方面,我也是个新人,这篇文章主要是给大家分享几种实现node 爬虫的方式.第一种方式,采用node,js中的 s ...
- sparksession创建DataFrame方式
spark创建dataFrame方式有很多种,官方API也比较多 公司业务上的个别场景使用了下面两种方式 1.通过List创建dataFrame /** * Applies a schema to a ...
- Mac查看及清理QQ、微信之前下载的图片、视频或DB等
之前写过一篇清理Mac空间的文章: Mac系统清理.占用空间大.空间不够.查看系统文件大小分布 其实这篇文章不是太全,有些资源还是清理不彻底,正好前段时间需要找微信下载的资源,其实可以算作空间清理的续 ...