当前位置: 首页 > news >正文

20251103折半搜索总结

引子

折半搜索(又称meet-in-the-middle)是一种优化搜索算法的方法。其说白了就是将搜索过程分成两个部分:先分别对两部分进行独立搜索,得到两个结果序列,最后通过合并这两个序列得到答案。

由于搜索算法的时间复杂度通常为指数级,当n较大时容易导致超时。采用折半搜索后,时间复杂度可由O(2n)O(2^n)O(2n)降到O(2n2+1)O(2^{\frac{n}{2}+1})O(22n+1)

C P4799 世界冰球锦标赛

折半搜索模板为何放在放在第三题?

这题就先折半搜索,接着合并时,我们可以先将一部分进行排列使其有序,然后遍历另一部分,每次进行二分搜索查找可行的答案,最后叠加可行方案数。

#include<bits/stdc++.h>usingnamespacestd;intn;longlongm,a[45];vector<longlong>a1,a2;voiddfs1(intk,longlongsum){if(sum>m)return;if(k>n/2){a1.push_back(sum);return;}dfs1(k+1,sum+a[k]);dfs1(k+1,sum);}longlongans=0;voiddfs2(intk,longlongsum){if(sum>m)return;if(k>n){a2.push_back(sum);return;}dfs2(k+1,sum+a[k]);dfs2(k+1,sum);}intmain(){cin>>n>>m;for(inti=1;i<=n;i++){cin>>a[i];}dfs1(1,0);dfs2(n/2+1,0);sort(a2.begin(),a2.end());for(autoi:a1){intp=upper_bound(a2.begin(),a2.end(),m-i)-a2.begin();ans+=p;}cout<<ans;return0;}
http://www.jsqmd.com/news/131470/

相关文章:

  • 全面讲解树莓派4的USB-C供电设计问题
  • 数字信号处理篇---复数
  • HSTS强制安全连接:杜绝降级威胁
  • 2025年度设计能力强的网站建设公司有哪些?国内十大服务商测评与企业适配指南
  • 图解说明FPU参与的单精度转换流程
  • 灾备切换实战测试:确保系统永不停机
  • 树莓派更换静态IP一文说清:适配最新Raspberry Pi OS
  • 官网FAQ自动更新:紧跟产品迭代节奏
  • 账单明细导出:清晰掌握消费构成
  • 10、Windows文件分析:VSC与MFT的深入探索
  • usb_burning_tool与定制化镜像结合的产线解决方案
  • 模拟电路直流工作点分析操作指南
  • 配置版本控制:Git管理所有设置项
  • 滚动升级策略:渐进式替换旧实例
  • 操作指南:如何在紧凑空间完成高效PCB布局设计
  • Java大厂面试实录:互联网医疗场景下的Spring Boot与微服务技术栈深度考验
  • 自媒体人必藏!4 个神仙小程序,解决权重 / 去水印 / 熬夜失眠难题
  • 11、Windows文件分析与事件日志解析全攻略
  • 负载均衡部署:支撑高并发访问需求
  • 成本优化建议:识别闲置资源并回收
  • MemOS Cloud | 云平台快速开始上手教程
  • 市场需求调研:AI辅助问卷设计与分析
  • 12、Windows系统文件分析:回收站、预取文件与计划任务
  • mptools v8.0量产模式下稳定性优化策略
  • IAR多工程管理技巧:项目组织最佳实践
  • 本地开发环境composer依赖导致could not find driver分析
  • 针对学生机房的proteus8.17下载及安装优化方案指南
  • 库存优化建议生成:数据驱动运营管理
  • 【机器学习】-带你弄懂时间序列
  • 三极管负反馈对放大性能的影响:系统学习