贪心算法:
在北美洲南部,有一篇神秘的海域,那里碧海蓝天、阳光明媚。
这正是传说中海盗最活跃的加勒比海。17世纪时,这里更是欧洲大陆的商旅舰队到达美洲的必经之地,
所以当时的海盗活动非常猖獗,海盗不仅攻击过往商人,甚至攻击英国皇家舰…
有一天,海盗们截获了一艘装满各种各样古董的货船,每一件古董都价值连城,
一旦打碎就失去了它的价值,虽然海盗船足够大,但载重量为C,每件古董的重量为wi,
海盗们该如何把尽可能多数量的宝贝装上海盗船呢?
可以模拟一下 最优解 就是 货物按照重量从小到大排序,然后装上船,计算装上船的总重量,
和船的最大载重量比较。
package com.woniuxy.work;import java.util.Arrays;/*** @author XiaoCheng* @date 2022/07/21 19:38:08* @Description: TODO*/ public class TanXin {//最优解就是 按照重量从小到大排序,然后搬上船 计算搬上去的总重量和穿的最大载重量比较public static void main(String[] args) {//c 代表船的总共载重量int c = 200;int count = 0; //count 表示 装的个数int weigths = 0;// weights 表示已经装上船的商品的总重量//模拟船上每件货物的重量int [] wi = {8, 64, 79, 15, 3, 23, 30, 45, 35, 12, 54, 46};Arrays.sort(wi);for (int i = 0; i < wi.length ; i++) {weigths = weigths + wi[i];if (weigths < c) {count++;//System.out.println("装进去的总重量是"+weigths);}else {break;}}System.out.println("总共装进去"+count+"个宝贝");}}