首页 > 分享 > 算法设计与分析

算法设计与分析

算法设计与分析-装载问题(回溯)

最新推荐文章于 2024-11-11 23:48:15 发布

偷吃了老鼠的土豆 于 2018-10-09 00:09:45 发布

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

题目:

描述:

有两艘船,载重量分别是c1、 c2,n个集装箱,重量是wi (i=1…n),且所有集装箱的总重量不超过c1+c2。确定是否有可能将所有集装箱全部装入两艘船。

输入:

多个测例,每个测例的输入占两行。第一行一次是c1、c2和n(n<=10);第二行n个整数表示wi (i=1…n)。n等于0标志输入结束。

输出:

对于每个测例在单独的一行内输出Yes或No。

输入样例:

7 8 2
8 7
7 9 2
8 8
0 0 0

输出样例:

Yes
No

来源:

tips:

求出c1 的bestw,如果r - bestw < c2 输出Yes

否则::::

#include <iostream>

#include <stdio.h>

#include <string.h>

#include <algorithm>

using namespace std;

int n,c1,c2,w[15];

int cw,bestw,r,x[15],bestx[15];

void backtrack(int i)

{

if(i > n) {

if(cw > bestw) bestw = cw;

return;

}

else {

r -= w[i];

if(cw + w[i] <= c1)

{

cw += w[i];

backtrack(i + 1);

cw -= w[i];

}

if(cw + r > bestw)

backtrack(i + 1);

r += w[i];

}

}

int main()

{

while(cin >> c1 >> c2 >> n && n)

{

cw = 0;

bestw = 0;r = 0;

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

{

cin >> w[i];

r += w[i];

}

backtrack(1);

if(r - bestw <= c2) cout << "Yes" << endl;

else cout << "No" << endl;

}

return 0;

}

相关知识

宠物行为分析算法
基于JAVA协同过滤算法网上宠物用品推荐购物商城系统设计与实现(Springboot框架)可行性分析
社交媒体用户特征分析平台的设计与实现
随机化算法(1) — 随机数
python宠物信息管理系统的思路,方法与算法
(SWUST OJ)《算法分析设计与实践》题库
递归算法的时间复杂度分析
基于协同过滤算法的宠物医院医疗推荐平台
宠物情绪分析与行为监测系统开发.pptx
基于AI的宠物行为分析与产品设计

网址: 算法设计与分析 https://m.mcbbbk.com/newsview810572.html

所属分类:萌宠日常
上一篇: 探索新安公园全新宠物友好空间,尽
下一篇: 手机QQ关闭空间宠物的方法 qq