贪心算法-背包算法-java实现

  
  
  1. /**
  2. * 贪心算法-背包算法:
  3. */
  4. public class Backpack {
  5. // 现有一个背包容量150kg
  6. // 有一个宝藏里面有很多物品,物品的重量和价值分别为:
  7. // 25kg--20
  8. // 30kg--40
  9. // 60kg--45
  10. // 35kg--50
  11. // 20kg--10
  12. // 50ke--45
  13. // 40ke--50
  14. private int[] weights = new int[] { 25, 30, 60, 35, 20, 50, 40 };// 物品重量
  15. private int[] values = new int[] { 20, 40, 45, 50, 10, 45, 50 };// 物品价值
  16. private int capacity = 150;
  17. /**
  18. * 根据物品重量和物品价值,求出每个物品的性价比-》将性价比进行排序-》选取性价比最高的物品添加到背包中-》直到背包不能再添加
  19. */
  20. public void backpack() {
  21. // step1:求物品性价比-》并从大到小排序
  22. int size = weights.length;// 物品数量
  23. double[] prices = new double[size];// 每个物品的性价比(每kg的价值)
  24. // 用一个数组用于保存排序后的性价比和最开始的物品重量的下标
  25. int[] tags = new int[size];
  26. for (int i = 0; i < size; i++) {
  27. prices[i] = (double) values[i] /weights[i] ;
  28. tags[i] = i;//默认排序
  29. }
  30. // 选择排序
  31. for (int i = 0; i < size; i++) {
  32. for (int j = i+1; j < size; j++) {
  33. if (prices[i] < prices[j]) {
  34. // 交换
  35. double temp = prices[i];
  36. prices[i] = prices[j];
  37. prices[j] = temp;
  38. int tag = tags[i];
  39. tags[i] = tags[j];
  40. tags[j] = tag;
  41. }
  42. }
  43. }
  44. // 根据已经从大到小排好序的性价比,和相对应的重量和价值,添加到背包中
  45. for (int i = 0; i < size; i++) {
  46. // 根据tags数组中重量的下标,拿到重量
  47. if (weights[tags[i]] < capacity) {
  48. System.out.println("添加物品" + weights[tags[i]]);
  49. capacity = capacity - weights[tags[i]];
  50. }
  51. }
  52. }
  53. public static void main(String[] args) {
  54. Backpack backpack = new Backpack();
  55. backpack.backpack();
  56. }
  57. }

结果打印:

添加物品35

添加物品30

添加物品40

添加物品25



  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值