装载问题(回溯法)

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 小时前
2025.11.16 力扣每日一题
算法
爬山算法1 小时前
Redis(127)Redis的内部数据结构是什么?
数据结构·数据库·redis
Justinyh1 小时前
1、CUDA 编程基础
c++·人工智能
Kuo-Teng2 小时前
LeetCode 118: Pascal‘s Triangle
java·算法·leetcode·职场和发展·动态规划
Greedy Alg2 小时前
LeetCode 32. 最长有效括号(困难)
算法
white-persist2 小时前
差异功能定位解析:C语言与C++(区别在哪里?)
java·c语言·开发语言·网络·c++·安全·信息可视化
ShineWinsu2 小时前
对于数据结构:链式二叉树的超详细保姆级解析—中
数据结构·c++·算法·面试·二叉树·校招·递归
合方圆~小文3 小时前
高性能20倍变焦球机转动功能监控设备
数据结构·数据库·数码相机·模块测试
野蛮人6号3 小时前
力扣热题100道之207课程表
算法·leetcode·职场和发展
这周也會开心3 小时前
Map的遍历方式
数据结构·算法