搜索树

剪枝方法

1.优化搜索顺序

2.排除等效冗余

3.可行性

4.最优性(估价)

5.记忆化(树形不会重复计算时不需要)

A.针对每个维度边界信息缩放、推倒

B.计算未来最少花费

C.结合各维度的联系

P1120 小木棍 

https://www.luogu.org/problemnew/show/P1120

bool dfs(int p,int u,int x)
{
if(p>cnt) return 1;
if(u==len) return dfs(p+1,0,1);
int lf=0;
FOR(i,x,n)
if((!vis[i])&&a[i]+u<=len&&a[i]!=lf)//剪枝2
{
vis[i]=1;
if(dfs(p,a[i]+u,i+1)) return 1;
vis[i]=0;lf=a[i];
if(u+a[i]==len||u==0) return 0;//剪枝3.4
}
return 0;
}
int main()
{
//freopen("hh.in","r",stdin);
nnn=rd();
FOR(i,1,nnn)
{
int tptp=rd();
if(tptp>50) continue;
a[++n]=tptp,cc+=a[n],gmax(mx,a[n]);
}
sort(a+1,a+n+1,greater<int>() );
//FOR(i,1,n) cout<<a[i]<<" ";cout<<endl;
for(len=mx;len<=cc;++len)
{
if(cc%len) continue;
cnt=cc/len;
memset(vis,0,sizeof(vis));
if(dfs(1,0,1)){cout<<len;break;}
}
return 0;
}

P1731 [NOI1999]生日蛋糕

https://www.luogu.org/problemnew/show/P1731

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
#define FOR(i,a,b) for(register int i(a);i<=b;++i)
#define For(i,a,b) for(register int i(a);i>=b;--i)
int mins[20],minv[20];
int ans=1<<30,s;
bool prune(int maxh,int maxr,int n,int v)
{
int cc=0;
FOR(i,0,n-1) cc+=(maxh-i)*(maxr-i)*(maxr-i);
if(cc<v) return 1;
else return 0;
}
void dfs(int maxh,int maxr,int n,int v,int m)
{
if(n==0)
{
if(v) return;
ans=min(ans,s);
}
if(s+mins[n]>ans) return;
if(maxh<n||maxr<n) return;
if(minv[n]>v) return;
if(prune(maxh,maxr,n,v)) return;
For(i,maxr,n)
{
if(n==m) s=i*i;
For(j,maxh,n)
{
s+=2*i*j;
dfs(j-1,i-1,n-1,v-i*i*j,m);
s-=2*i*j;
}
}
}
int main()
{
int n,m;scanf("%d%d",&n,&m);
FOR(i,1,m)
mins[i]=mins[i-1]+2*i*i,
minv[i]=minv[i-1]+i*i*i;
if(n<minv[m]) printf("0");
else
{
int maxh=(n-minv[m-1])/(m*m)+1;
int maxr=sqrt((n-minv[m-1])/m)+1;
dfs(maxh,maxr,m,n,m);
if(ans==1<<30) printf("0");
else printf("%d",ans);
} return 0;
}

迭代加深

a.搜索树规模增长快

b.从小到大限制深度

双向搜索

“终态”明确,路径可逆

CH2401 送礼物

http://contest-hunter.org:83/contest/0x20%E3%80%8C%E6%90%9C%E7%B4%A2%E3%80%8D%E4%BE%8B%E9%A2%98/2401%20%E9%80%81%E7%A4%BC%E7%89%A9

先从前(N/2+2)中选若干个,存放,排序,去重

再枚举后一半,二分查找对应的前一半的值

 1 void dfs1(int i, unsigned int sum) {
2 if (i == half) {
3 a[++m] = sum;
4 return;
5 }
6 dfs1(i + 1, sum);
7 if (sum + g[i] <= w) dfs1(i + 1, sum + g[i]);
8 }
9
10 void calc(unsigned int val) {
11 int rest = w - val;
12 int l = 1, r = m;
13 while (l < r) {
14 int mid = (l + r + 1) / 2;
15 if (a[mid] <= rest) l = mid; else r = mid - 1;
16 }
17 ans = max(ans, a[l] + val);
18 }
19
20 void dfs2(int i, unsigned int sum) {
21 if (i == n + 1) {
22 calc(sum);
23 return;
24 }
25 dfs2(i + 1, sum);
26 if (sum + g[i] <= w) dfs2(i + 1, sum + g[i]);
27 }
28
29 int main() {
30 cin >> w >> n;
31 for (int i = 1; i <= n; i++) scanf("%d", &g[i]);
32 sort(g + 1, g + n + 1);
33 reverse(g + 1, g + n + 1);
34 half = n / 2 + 3;
35 dfs1(1, 0);
36 sort(a + 1, a + m + 1);
37 m = unique(a + 1, a + m + 1) - (a + 1);
38 dfs2(half, 0);
39 cout << ans << endl;
40 }

IDA*

估价函数+迭代加深

若当前深度+未来估价>深度限制,立即回溯

dfs剪枝与优化的更多相关文章

  1. hdu 4109 dfs+剪枝优化

    求最久时间即在无环有向图里求最远路径 dfs+剪枝优化 从0节点(自己添加的)出发,0到1~n个节点之间的距离为1.mt[i]表示从0点到第i个节点眼下所得的最长路径 #include<iost ...

  2. [洛谷P1731][NOI1999]生日蛋糕(dfs)(剪枝)

    典型的深搜+剪枝策略 我们采用可行性剪枝.上下界剪枝.优化搜索顺序剪枝.最优性剪枝的方面来帮助我们进行剪枝. 也许有人还不知道剪枝,那我就弱弱地为大家补习一下吧qwq: .优化搜索顺序: 在一些搜索问 ...

  3. hdu 5887 Herbs Gathering (dfs+剪枝 or 超大01背包)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5887 题解:这题一看像是背包但是显然背包容量太大了所以可以考虑用dfs+剪枝,贪心得到的不 ...

  4. 生日蛋糕 (poj1190) (dfs剪枝)

    [题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1 <= i <= M)层蛋糕是半径为Ri, 高度为 ...

  5. [Codeforces 163D]Large Refrigerator (DFS+剪枝)

    [Codeforces 163D]Large Refrigerator (DFS+剪枝) 题面 已知一个长方体的体积为V,三边长a,b,c均为正整数,求长方体的最小表面积S V以质因数分解的形式给出 ...

  6. Sticks(UVA - 307)【DFS+剪枝】

    Sticks(UVA - 307) 题目链接 算法 DFS+剪枝 1.这道题题意就是说原本有一些等长的木棍,后来把它们切割,切割成一个个最长为50单位长度的小木棍,现在想让你把它们组合成一个个等长的大 ...

  7. POJ2688状态压缩(可以+DFS剪枝)

    题意:       给你一个n*m的格子,然后给你一个起点,让你遍历所有的垃圾,就是终点不唯一,问你最小路径是多少? 思路:       水题,方法比较多,最省事的就是直接就一个BFS状态压缩暴搜就行 ...

  8. *HDU1455 DFS剪枝

    Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  9. POJ 3009 DFS+剪枝

    POJ3009 DFS+剪枝 原题: Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16280 Acce ...

  10. poj 1724:ROADS(DFS + 剪枝)

    ROADS Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10777   Accepted: 3961 Descriptio ...

随机推荐

  1. Android 7 修改启动动画和开机声音

    背景 在修改开机音量的时候,发现找不到对应的声音功能调用. 因此了解了一下安卓的开机声音是如何实现的. 安卓4~安卓7 都可以这么做. 参考: https://blog.csdn.net/chen82 ...

  2. 使用explain优化慢查询的业务场景分析

    问:你最害怕的事情是什么? 答:搓澡 问:为什么? 答:因为有些人一旦错过,就不在了 Explain 这个词在不同的上下文中有不同的含义.在数据库查询优化的上下文中,"EXPLAIN&quo ...

  3. NXP i.MX 8M Mini工业核心板硬件说明书(四核ARM Cortex-A53 + 单核ARM Cortex-M4,主频1.6GHz)

    1          硬件资源 创龙科技SOM-TLIMX8是一款基于NXP i.MX 8M Mini的四核ARM Cortex-A53 + 单核ARM Cortex-M4异构多核处理器设计的高端工业 ...

  4. python3 socket 获取域名信息

    可以当ping用,应用场景可以在一些没有安装ping工具的镜像容器中,诊断dns或域名的可用性. #-*- coding:utf-8 -*- import socket import tracebac ...

  5. JpaRepository:Paging query needs to have a Pageable parameter! Offending method public abstract

    在练习 Spring Data JPA 时,使用分页接口 Pageable 查询数据,接口实现后,运行报错: Paging query needs to have a Pageable paramet ...

  6. RAG工程实践拦路虎之一:PDF格式解析杂谈

    背景 PDF(Portable Document Format)是一种广泛用于文档交换的文件格式,由Adobe Systems开发.它具有跨平台性.固定布局和易于打印等特点,因此在商业.学术和个人领域 ...

  7. yb课堂 ECMAScript 6常见语法快速入门 《三十一》

    什么是ES 6 ECMAScript 6(简称ES6)是于2015年6月正式发布的JavaScript语言的标准,正式名为ECMAScript 2015(ES2015).它的目标是使用JavaScri ...

  8. QCon 回顾 | Data Fabric:逻辑统一、物理分散

    Data Fabric(数据编织),自 2019 年开始就在 Gartner 年度技术趋势榜单上安家,并在 2022 年被列为数据分析领域十大技术趋势之首,它究竟有哪些价值?又如何在企业落地? 在近日 ...

  9. oeasy教您玩转vim - 37 - # 删除字符

    ​ 通过十进制的 ascii 值输入字符 在输入模式下 输入 ctrl + v 然后再输入 065 通过十六进制的 unicode 在输入模式下 输入 ctrl + v 然后再输入 u2642 就可以 ...

  10. 数据分析应该掌握的知识及SQL技能

    一.概念及常识 1.数据分析必备的统计学知识 描述统计学 1.平均值.中位数.众数 2.方差.标准差 3.统计分布:正态分布.指数分布.二项分布.卡方分布 推论统计学 1.假设检验 2.置信区间 3. ...