装载问题(回溯法)

cpp 复制代码
#include<iostream>
using namespace std;
int n;//货物的数量
int c;//轮船的总的载重量
int cw;//轮船当前的载重量
int r;//货物的总重量
int w[1000];//n个货物各自的重量
int x[1000];//当前最优解
int bestx[1000];//最优解
int bestw;//货物的最优载重量
void BackTrack(int s)
{
    if(s>n)
    {
        if(cw>bestw)
        {
            bestw=cw;
            for(int i=1;i<=n;i++)
                bestx[i]=x[i];
        }
        return ;
    }
    r-=w[s];
    if(cw+w[s]<=c)
    {
        x[s]=1;
        cw+=w[s];
        BackTrack(s+1);
        cw-=w[s];
    }
    if(cw+r>bestw)
    {
        x[s]=0;
        BackTrack(s+1);
    }
    r+=w[s];
}
int main()
{
    cout<<"轮船的总载重量:";cin>>c;
    cout<<"货物的数量:";cin>>n;
    cout<<"货物各自的重量:";
    for(int i=1;i<=n;i++)
    {
        cin>>w[i];
        r+=w[i];
    }
    BackTrack(1);
    cout<<"货物的最优载重量:"<<bestw<<endl;
    cout<<"最优解:"<<endl;
    for(int i=1;i<=n;i++)
        cout<<bestx[i];
    cout<<endl;
    for(int i=1;i<=n;i++)
        if(bestx[i]==1)
            cout<<i<<" ";
    return 0;
}
相关推荐
七颗糖很甜1 分钟前
开源雷达NEXRAD Level 3 数据完整获取与 Python 处理教程
大数据·python·算法
JXNL@4 分钟前
TDK DPX105950DT 射频双工器全解析:从原理、参数到应用设计
算法
池塘的蜗牛5 分钟前
FMCW(2)-速度
算法
菜菜的顾清寒7 分钟前
力扣hot100(21)搜索二维矩阵 II
算法·leetcode·职场和发展
楼田莉子7 分钟前
CMake学习:动态库场景下的应用
c++·后端·学习·软件构建
jingshaoqi_ccc9 分钟前
使用QT6创建一个可编辑的表格并导出和载入
c++·qt·表格
liuyao_xianhui13 分钟前
Linux开发工具结尾 _make
linux·运维·服务器·数据结构·哈希算法·宽度优先·1024程序员节
️是7817 分钟前
信息奥赛一本通—编程启蒙(3380:练65.3 螺旋矩阵)
线性代数·算法·矩阵
天若有情67319 分钟前
C++进阶:普通重载运算符 vs 隐式类型转换重载运算符,一篇讲透区别
开发语言·c++·算法
云深麋鹿27 分钟前
C++ | 二叉搜索树
开发语言·c++