五大算法之贪心法

本贴最后更新于 2683 天前,其中的信息可能已经斗转星移

问题:一个旅行者有一个最多能用c公斤的背包,现在有n件物品,每件的重量分别是w1,w2,...,wn,每件的价值分别为v1,v2,...,vn,若每种物品都可无限细分,求旅行者能获得的最大总价值。

抽象:组合出价值最大的指定重量的物品。

思路:先求出每个物品的价值密度,先放入价值密度最大的物品,再放入剩余物品价值密度最大的物品,依次进行,直到背包已满。

代码:

package test;

import java.util.Arrays;

/**

  • 贪心法求背包问题(可分割)
  • @author yanghang

*/
public class Tanxin {

public static void main(String[] args) {
	/**
	 * 初始化
	 */
	// 背包的容量
	double c = 12;
	// 物品的数量
	int n = 5;
	// 物品重量数组
	double[] w = new double[n];
	// 物品价钱数组
	double[] v = new double[n];
	// 物品的重量  1,2,3,4,5
	for (int i = 0; i < n; i++) {
		w[i] = i + 1;
	}
	// 物品的价值 5,4,3,2,1
	for (int i = 0; i < n; i++) {
		v[i] = n - i;
	}
	
	/**
	 * 求出单位重量价值r[i] = v[i] / w[i]
	 * 
	 */
	double[] r = new double[n];
	int[] index = new int[n];
	for (int i = 0; i < n; i++) {
		r[i] = (double) v[i] / (double) w[i];
		index[i] = i;
	}

	/**
	 * 按照价值密度排序
	 */
	double temp = 0;
	for (int i = 0; i < n - 1; i++) {
		for (int j = i + 1; j < n; j++) {
			if (r[i] < r[j]) {
				temp = r[i];
				r[i] = r[j];
				r[j] = temp;
				temp = w[i];
				w[i] = w[j];
				w[j] = temp;
				temp = v[i];
				v[i] = v[j];
				v[j] = temp;
			}
		}
	}

	/**
	 * 初始化解向量x[n],求解并打印解向量
	 */
	double[] x = new double[n];
	for (int i = 0; i < n; i++) {
		if (w[i] <= c) {
			x[i] = 1;
			c = c - w[i];
		} else if (w[i] > c) {
			x[i] = (double)c / w[i];
			c = 0;
			break;
		}
	}
	System.out.println("解向量是:" + Arrays.toString(x));
	
	
	/**
	 * 根据解向量求出背包中存放物品的最大价值并打印
	 */
	double maxValue = 0;
	for (int i = 0; i < n; i++) {
		maxValue += v[i] * x[i];
	}
	System.out.println("背包中物品的最大价值为:" + maxValue);

}

}

 

  • 算法
    388 引用 • 254 回帖 • 22 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • donychen

    无意中看到这个帖子,对其中的算法思路不是很理解。
    // 背包的容量 double c = 12;
    // 物品的数量 int n = 5;
    // 物品的重量 1,2,3,4,5
    // 物品的价值 5,4,3,2,1
    用最简单的思路想一下,重量为 1 的物品价值是 5。
    换句话,重量最轻的物品最贵,那么我只要装 12 个重量为 1 的商品,就能获得 12*5=60 的最大价值。
    根据你的程序输出:
    解向量是:[1.0, 1.0, 1.0, 1.0, 0.4]
    背包中物品的最大价值为:14.4
    为什么?

推荐标签 标签

  • 倾城之链
    23 引用 • 66 回帖 • 100 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 21 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 23 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    396 引用 • 3416 回帖
  • 笔记

    好记性不如烂笔头。

    303 引用 • 777 回帖
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 544 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 423 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    70 引用 • 532 回帖 • 712 关注
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    82 引用 • 122 回帖 • 621 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    75 引用 • 145 回帖 • 1 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    131 引用 • 3639 回帖
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 6 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 53 关注
  • 996
    13 引用 • 200 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    333 引用 • 323 回帖 • 65 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 18 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 26 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    19 引用 • 23 回帖 • 685 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 345 关注
  • OnlyOffice
    4 引用 • 24 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 588 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    710 引用 • 1173 回帖 • 171 关注
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    313 引用 • 1666 回帖
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 247 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 291 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1425 引用 • 10043 回帖 • 468 关注