算法设计与分析第五章作业

我的代码:

#include<bits/stdc++.h>

using namespace std;

int n,m,d;

int minweight=INT_MAX;

int cv=0;

int cw=0;

vector<vector<int>> w;

vector<vector<int>> v;

vector<int> x;

vector<int> xi;

void back(int wu){

if(wu>n){

if(cw<minweight){

minweight=cw;

for(int k=1;k<=n;k++){

xi[k]=x[k];

}

}

return ;

}

for(int i=1;i<=m;i++){

if(cw+w[wu][i]>minweight){

continue;

}

if(cv+v[wu][i]<=d){

cv+=v[wu][i];

cw+=w[wu][i];

x[wu]=i;

back(wu+1);

cv-=v[wu][i];

cw-=w[wu][i];

x[wu]=-1;

}

}

}

int main(){

cin>>n>>m>>d;

w.resize(n+1,vector<int>(m+1));

v.resize(n+1,vector<int>(m+1));

x.resize(n+1,-1);

xi.resize(n+1);

for(int i=1;i<=n;i++)

for(int j=1;j<=m;j++){

cin>>v[i][j];

}

for(int i=1;i<=n;i++)

for(int j=1;j<=m;j++){

cin>>w[i][j];

}

back(1);

cout<<minweight<<endl;

for(int j=1;j<=n;j++) cout<<xi[j]<<" ";

return 0;

}

1. 请用回溯法的方法分析"最小重量机器设计问题"

1.1 说明"最小重量机器设计问题"的解空间

解空间可以看作是所有可能的组件选择组合。每个组件有多个选项(比如不同的型号或配置),每个选项有其特定的重量和性能值。解空间由所有这些选项的不同组合构成,每个组合代表一个可能的机器设计。

1.2 说明 "最小重量机器设计问题"的解空间树

解空间树是一种树形结构,用于表示所有可能的解空间。在这个问题中,解空间树的每个节点代表一个决策点,即在某个组件上选择哪个选项。树的深度等于组件的数量(n),树的宽度等于每个组件的选项数量(m)。

从根节点开始,每个节点向下有m个子节点,分别对应一个组件的m个选项。树的叶子节点代表一个完整的机器设计,即所有组件都已选择了一个选项。

1.3 在遍历解空间树的过程中,每个结点的状态值是什么

在遍历解空间树的过程中,每个节点的状态值可以包括:

  • 当前重量(cw):从根节点到当前节点为止,所有已选组件的总重量。

  • 当前性能值(cv):从根节点到当前节点为止,所有已选组件的总性能值。

  • 当前选择的组件选项(x):一个数组,记录从根节点到当前节点为止,每个组件选择的选项编号。

  • 当前节点对应的组件编号(wu):表示当前正在考虑哪个组件的选择。

我的代码中,这些状态值通过全局变量和函数参数进行传递和更新:

  • cwcv 分别表示当前的总重量和总性能值。
  • x 是一个数组,用于记录每个组件选择的选项编号。
  • wu 是一个函数参数,表示当前正在考虑的组件编号。

1.4 如何利用限界函数进行剪枝

for(int i=1;i<=m;i++){

if(cw+w[wu][i]>minweight){

continue;

}

如果这个总重量已经大于到目前为止找到的最小重量 minweight,那么即使继续搜索下去,也不可能找到一个更轻的设计,直接剪掉。

2. 你对回溯算法的理解

回溯算法是一种通过探索所有可能的候选解来找出所有解的算法。它采用试错的思想,在搜索过程中逐步构建解,当发现当前选择不能得到解时,就回溯到上一步,尝试其他选择。

相关推荐
AI_Keymaker30 分钟前
一句话生成3D世界:腾讯开源混元3D模型
算法
Leon_vibs33 分钟前
当 think 遇上 tool:深入解析 Agent 的规划之道
算法
旧时光巷40 分钟前
【机器学习-2】 | 决策树算法基础/信息熵
算法·决策树·机器学习·id3算法·信息熵·c4.5算法
落羽的落羽42 分钟前
【C++】论如何封装红黑树模拟实现set和map
数据结构·c++·学习
落了一地秋1 小时前
4.5 优化器中常见的梯度下降算法
人工智能·算法·机器学习
前端伪大叔1 小时前
第 5 篇:策略参数怎么调优?Freqtrade hyperopt 快速入门
算法·代码规范
Code季风1 小时前
深入理解令牌桶算法:实现分布式系统高效限流的秘籍
java·算法·微服务
KyollBM2 小时前
【Luogu】每日一题——Day15. P1144 最短路计数 (记忆化搜索 + 图论 + 最短路)
算法·图论
一百天成为python专家2 小时前
K-近邻算法
数据结构·python·算法·pandas·近邻算法·ipython·python3.11
满分观察网友z2 小时前
告别烦人的“三连发”:我的智能评论系统过滤之旅(1957. 删除字符使字符串变好)
算法