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,好开心) ================ ...
随机推荐
- Django使用本机IP无法访问,使用127.0.0.1能正常访问
使用Django搭建web站点后,使用127.0.0.1能访问,但是用自己本机IP却无法访问. 我们先到Django项目中找到setting文件 找到——> ALLOWED_HOSTS = [] ...
- Python基础总结之认识lambda函数、map函数、filter() 函数。第十二天开始(新手可相互督促)
今天周日,白天在学习,晚上更新一些笔记,希望对大家能更好的理解.学习python~ lambda函数,也就是大家说的匿名函数.它没有具体的名称,也可以叫做一句话函数,我觉得也不过分,大家看下代码,来体 ...
- selenium操作cookies实现免密登录,自动发微博
一直想用selenium实现个小功能,比如发微博之类的,但是有的网站在登录会有验证码,没想到太好的方法解决,于是想到利用cookies来登录网站 第一步:获取一个可用的cookies,获取的cooki ...
- 一文读懂tomcat组件--一个web服务器的架构演化史
1. tomcat是谁? 2. tomcat可以做什么? tomcat是一个web容器,可以将web应用部署到tomcat,由它提供web服务,一个web容器中可以部署多个web应用,这些we ...
- 【POJ - 2385】Apple Catching(动态规划)
Apple Catching 直接翻译了 Descriptions 有两棵APP树,编号为1,2.每一秒,这两棵APP树中的其中一棵会掉一个APP.每一秒,你可以选择在当前APP树下接APP,或者迅速 ...
- springboot自动配置源码解析
springboot版本:2.1.6.RELEASE SpringBoot 自动配置主要通过 @EnableAutoConfiguration, @Conditional, @EnableConfig ...
- python(自用手册)导图
- Windows Server 2008配置系统安全策略
下面学习Windows Server 2008配置系统安全策略 在工作组中的计算机本地安全策略有 用户策略,密码策略,密码过期默认42天 服务账户设置成永不过期,帐户锁定策略,本地策略,审核策略,计算 ...
- Go-json解码到结构体-踩坑
package main import ( "encoding/json" "fmt" ) type User struct { Name string `js ...
- html页面中关于按钮type的要求
重要事项:如果在 HTML 表单中使用 button 元素,不同的浏览器会提交不同的值.Internet Explorer 将提交 <button> 与 </button> 之 ...