装载问题(回溯法)

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;
}
相关推荐
余瑜鱼鱼鱼3 分钟前
Java数据结构:从入门到精通(五)
数据结构
威桑7 分钟前
交叉编译过程中的踩坑与收获
linux·c++·arm·交叉编译
君义_noip9 分钟前
信息学奥赛一本通 1951:【10NOIP普及组】导弹拦截 | 洛谷 P1158 [NOIP 2010 普及组] 导弹拦截
c++·算法·csp-j·信息学奥赛
环黄金线HHJX.9 分钟前
《QuantumTuan ⇆ QT:Qt》
人工智能·qt·算法·编辑器·量子计算
jz_ddk10 分钟前
[实战] 射频相位噪声单位转换:从dBc/Hz到rad
算法·rf·射频·相位噪声·相噪
zl_vslam11 分钟前
SLAM中的非线性优-3D图优化之地平面约束(十五)
人工智能·算法·计算机视觉·3d
空空潍14 分钟前
hot100-滑动窗口最大值(day11)
数据结构·c++·算法·leetcode
朔北之忘 Clancy17 分钟前
2025 年 6 月青少年软编等考 C 语言一级真题解析
c语言·开发语言·c++·学习·算法·青少年编程·题解
guygg8818 分钟前
结合VD算法与IMM算法的卡尔曼滤波机动目标跟踪方法
人工智能·算法·目标跟踪
R-G-B28 分钟前
BM28 二叉树的最大深度
数据结构·算法·二叉树·bm28·二叉树的最大深度