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

山东诚铭建设机械有限公司网站站内内容投放计划

山东诚铭建设机械有限公司网站,站内内容投放计划,wordpress 会员系统,企业网站代码模板下载剪枝 将搜索过程中一些不必要的部分剔除掉#xff0c;因为搜索过程构成了一棵树#xff0c;剔除不必要的部分#xff0c;就像是在树上将树枝剪掉#xff0c;故名剪枝。 剪枝是回溯法中的一种重要优化手段#xff0c;方法往往先写一个暴力搜索#xff0c;然后找到某些特…剪枝 将搜索过程中一些不必要的部分剔除掉因为搜索过程构成了一棵树剔除不必要的部分就像是在树上将树枝剪掉故名剪枝。 剪枝是回溯法中的一种重要优化手段方法往往先写一个暴力搜索然后找到某些特殊的数学关系或者逻辑关系通过它们的约束让搜索树尽可能浅而小从而达到降低时间复杂度的目的。 一般来说剪枝的复杂度难以计算。 例题 蓝桥oj2942数字王国之军训排队 问题描述 数字王国开学了它们也和我们人类一样有开学前的军训现在一共有 n 名学生每个学生有自己的一个名字 ai​数字王国里的名字就是一个正整数注意学生们可能出现重名的情况此时叛逆教官来看了之后感觉十分别扭决定将学生重新分队。 排队规则为将学生分成若干队每队里面至少一个学生且每队里面学生的名字不能出现倍数关系注意名字相同也算是倍数关系。 现在请你帮忙算算最少可以分成几队 例有 4 名学生 (2,3,4,4)最少可以分成 (2,3)、(4)、(4) 共 3 队。 输入格式 第一行包含一个正整数 n表示学生数量。 第二行包含 n 个由空格隔开的整数第 i 个整数表示第 i 个学生的名字 ai​。 输出格式 输出共 1 行包含一个整数表示最少可以分成几队。 样例输入 4 2 3 4 4样例输出 3解1.不剪枝 #include iostream #includevector #includealgorithm using namespace std; const int N 15; int a[N],n;vectorintv[N];//v[i]表示第i组里面所有人的编号//cnt表示队伍数量dfs返回在cnt个队伍的情况下是否可以成功分组bool dfs(int cnt, int dep) {if (dep n 1){//说明每个人都成功分组了//检查当前方案的合法性for (int i 1; i cnt; i)//每个队伍枚举里面所有的二元组{for (int j 0; j v[i].size(); j){for (int k j1; k v[i].size(); k){if (v[i][k] % v[i][j] 0)return false;}}}return true;}//枚举每个人所属的队伍for (int i 1; i cnt; i){v[i].push_back(a[dep]);if (dfs(cnt, dep 1))return true;//恢复现场v[i].pop_back();}return false; }int main() {// 请在此输入您的代码cin n;for (int i 1; i n; i)cin a[i];sort(a 1, a 1 n);//枚举n个for (int i 1; i n; i){if (dfs(i, 1))//i个队伍从第一层开始搜索看这种情况是否可以装的下即成功分组{cout i endl;break;}}return 0; } 解2.剪枝我没太懂先放着 #include iostream #includevector #includealgorithm using namespace std; const int N 15; int a[N],n;vectorintv[N];//v[i]表示第i组里面所有人的编号//cnt表示队伍数量dfs返回在cnt个队伍的情况下是否可以成功分组bool dfs(int cnt, int dep) {if (dep n 1){//说明每个人都成功分组了//检查当前方案的合法性for (int i 1; i cnt; i)//每个队伍枚举里面所有的二元组{for (int j 0; j v[i].size(); j){for (int k j1; k v[i].size(); k){if (v[i][k] % v[i][j] 0)return false;}}}return true;}//枚举每个人所属的队伍for (int i 1; i cnt; i){bool tag true; for(const auto j:v[i])if (a[dep] % j 0){tag false;break;} if (!tag)continue;v[i].push_back(a[dep]);if (dfs(cnt, dep 1))return true;//恢复现场v[i].pop_back();}return false; }int main() {// 请在此输入您的代码cin n;for (int i 1; i n; i)cin a[i];sort(a 1, a 1 n);//枚举n个for (int i 1; i n; i){if (dfs(i, 1))//i个队伍从第一层开始搜索看这种情况是否可以装的下即成功分组{cout i endl;break;}}return 0; }
http://www.hkea.cn/news/14286946/

相关文章:

  • 开通公司网站怎么做分录宁波优化seo软件公司
  • 遵义一般做一个网站需要多少钱有做分期海淘的网站吗
  • 公司做网站个人网站和企业网站
  • 网站降权怎么做用网站做淘宝客的人多吗
  • 网站小视频怎么做代理计算机专业网站毕业设计
  • 小企业网站建设地点长沙网页设计师招聘信息
  • 网站建设办法大型购物网站建设
  • 一个人做网站的swot襄樊大型网站建设
  • 绿色环保材料网站模板下载不允许访问网站
  • 淘宝客网站的建设网站及其建设的心得
  • 深圳网站制作公司兴田德润在哪里WordPress多页悬浮菜单
  • 如何设计一个高端网站简洁大方大气网站建设的一些销售技巧
  • 郑州互助盘网站开发互助平台网站建设
  • 模板做图 网站jsp是前端还是后端开发的
  • 金华网站建设策划书画展示网站源码
  • 大钢模板相关信息圆柱钢模板优势是什么?企业网站建设模板和定制化有什么区别呢?人工费多少钱一平方珍岛网站建设
  • 在哪里做网站安徽合肥制作网站公司吗
  • 有没有专业做二维码连接网站在wordpress qq群
  • 重庆产品推广类网站网站开发兼容
  • 做前端常用的网站及软件下载wordpress上传视频失败
  • 广告网站制作多少钱公司取名网
  • 网站开发三步东莞长安网站开发公司
  • 简述网站的建站流程全国优秀作文选官网
  • wordpress代刷网seo 的作用和意义
  • 兰州市建设局网站国贸大厦工业设计网站导航
  • 资源下载网站源码管理系统 网站模板
  • 公司网站平台建设外国人做家具的网站
  • 学做古装网站微信怎么开自己的公众号
  • tornado 网站开发网站开发过程代码问题 解决
  • 手工业网站怎么做wordpress 设置密码