- 浏览: 2049861 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (795)
- java (263)
- 聚类搜索引擎 (9)
- 经验之谈 (67)
- DSP (3)
- C++ (140)
- Linux (37)
- SNMP (6)
- Python (6)
- 数据库 (61)
- 网络 (20)
- 算法 (15)
- 设计模式 (4)
- 笔试题 (38)
- 散文 (35)
- 数据结构 (9)
- 银行知识 (0)
- 榜样 (9)
- Lucene (15)
- Heritrix (6)
- MetaSeeker (0)
- netbeans (12)
- php (3)
- 英语 (8)
- DB2 (0)
- java基础 (5)
- mongodb & hadoop (4)
- Javascript (7)
- Spring (4)
- ibatis & myibatis (1)
- velocity (1)
- 微服务 (0)
- paddle (1)
- 第三方 (0)
- 知识沉淀 (1)
- 建模 (0)
最新评论
-
0372:
标示对java很陌生!
中文乱码解决的4种方式 -
梦留心痕:
Java中\是转意字符, 可是你的这句话我没看懂,只要把得到的 ...
java中如何忽略字符串中的转义字符--转载 -
yanjianpengit:
[b][/b]
java为什么非静态内部类里面不能有静态成员 -
springdata-jpa:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
eclipse 如何把java项目转成web项目 -
qq1130127172:
,非常好。
(转)SpringMVC 基于注解的Controller @RequestMapping @RequestParam..
/** * 背包问题 * 背包问题是计算机科学里的经典问题。在最简单的形式中,包括试图将不同重量的数据项放到 * 背包中.以使背包最后达到指定的总重量。不需要把所有的选项都放入背包中。 * 举例来说,假设想要背包精确地承重20磅,并且有5个可以选择放入的数据项,它们的重量 * 依次为11磅、8磅、7磅、6磅和5磅。对于选择放入的数据项数量不大时,人类很善于通过观察 * 就可以解决这个问题。于是大概可以计算出只有8磅、7磅和5磅的数据项加在一起和为20磅。 * 如果想要计算机来解决这个问题,就需要给计算机更详细的指令。算法如下: * 1.如果在这个过程中的任何时刻,选择的数据项的总和符合目标重量,工作就完成了。 * 2.从选择第一个数据项开始。剩余的数据项的加和必须符合背包的目标重量减去第一个数据 * 项的重量;这是一个新的目标重量。 * 3.逐个地试每种剩余数据顶组合的可能性。但是,注意并不需要去试所有的组合,因为只要 * 数据顶朗和大于目标重量的时候,就停止添加数据项。 * 4.如果设有组合合适的话,放弃第—‘个数据项,并且从第二个数据项开始再重复一边整个 * 过程。 * 5.继续从第三个数据项开始,如此下去直到你已经试过所有的组合,这时知道没有解决答案 * 。 * 在刚刚描述的这个例子中,从11开始。现在想要剩余的数据项和为9(20减去u)。对于9, * 从很小的8开始。现在想要剩余的数据项和为1(9减去8)。从7开始,但是它大于L,于是尝 * 试6,然后试5*它们都太大了d现在已经试过了所有的数据项,所以知道包含8的任何组合 * 和都不可能为9。接着尝试7,于是现在开始找的目标为2(9减去7)。 * */ public class Beibao{ static int[] a=new int[5]; //背包重量 static int[] b=new int[5]; //结果数组 static int flag=0; //下一个候选项 static int bound=20; //总重量 static int totle=0; //每次选择后的总重量 public static void inserttry(int i,int leftbound,int t){ if(i<5&&leftbound<=totle){ if(a[i]<leftbound){ b[t++]=a[i]; totle=totle-a[i]; leftbound=leftbound-a[i]; i++; inserttry(i,leftbound,t); } else if(a[i]>leftbound){ totle=totle-a[i]; i++; inserttry(i,leftbound,t); } else { b[t]=a[i]; return; } } else { leftbound=leftbound+b[--t]; for(int f=0;f<5;f++) { if (a[f]==b[t]) {flag=++f; break;} } b[t]=0; totle=0; for(int m=flag;m<5;m++) { totle+=a[m]; } inserttry(flag,leftbound,t); } return; } public static void main(String[] args){ a[0]=11; a[1]=8; a[2]=6; a[3]=7; a[4]=5; for(int i=0;i<5;i++) { b[i]=0;} for(int i=0;i<5;i++) { totle+=a[i]; } inserttry(0,20,0); for(int i=0;i<5;i++){ System.out.println(b[i]); } } }
发表评论
-
流式计算
2022-02-07 14:31 286private void postHandle(List& ... -
消息队列使用的四种场景介绍
2018-08-09 16:34 2478以下介绍消息队列在实际应用中常用的使用场 ... -
设计模式
2018-04-11 16:49 9861.桥梁模式,将抽象部分与实现部分隔离开,抽象部分持有实现 ... -
Spring boot web可以访问Service和Mapper层
2018-03-26 16:42 2872Spring boot的web层可以访问Service层,然 ... -
FreeMarker的基础语法使用 && 心得和技巧
2018-01-10 10:03 2063FreeMarker是一个模板引 ... -
webService----wss4j+cxf实现WS-Security(基于UsernameToken)
2017-10-23 18:58 1561分享一下wss4j+cxf基于UsernameToken的安 ... -
Spring MVC之LocaleResolver(解析用户区域)
2017-09-23 15:55 2534为了让web应用程序支持国际化,必须识别每个用户的首选区域, ... -
(转)java泛型
2016-11-12 20:29 1650http://www.cnblogs.com/lwbqqyu ... -
java中如何忽略字符串中的转义字符--转载
2016-06-28 16:42 9916原文地址:http://my ... -
(转)关于JAP FetchType.LAZY(hibernate实现)的理解 .
2016-04-27 15:22 5108JPA定义实体之间的关系有如下几种: @OneToOne ... -
(转)hibernate annotation注解方式来处理映射关系
2016-04-26 16:52 1841http://www.cnblogs.com/xiao ... -
代码片段,导出的文件头
2015-11-18 20:34 1606public static void setDownload ... -
(转)为什么要两次调用encodeURI来解决乱码问题
2015-08-03 20:19 2489地址:http://blog.csdn.net/howla ... -
杀死进程
2015-07-21 14:54 1293sudo lsof -i :9000 COMMAND P ... -
批处理batch,执行多个SQL语句
2015-07-15 19:21 10616批处理batch,执行多个SQL语句。 ... -
中文乱码解决的4种方式
2015-07-03 14:20 2630目前收集到4中方法,中文传参一documentPath为例: ... -
GET请求的中文乱码问题及处理意义
2015-07-03 13:47 6635首先看一段乱码的程序 ... -
java.ByteArrayInputStream与ByteArrayOutputStream再次理解
2015-03-16 17:59 3242第一次看到ByteArrayOutputStream的时 ... -
(转)SpringMVC 基于注解的Controller @RequestMapping @RequestParam..
2014-07-28 17:42 2282概述 继 Spring 2.0 对 Spring MVC ... -
java中序列化的serialVersionUID解释
2014-07-25 09:26 1891serialVersionUID: 字面意思上是序列化的版本号 ...
相关推荐
原先在网上找到某位大虾写的一个简单的背包算法,于是在其基础上改成适合我们目前项目中要求的背包算法。此算法要求传入一组对象集合(其中的对象中只包含主键和值)和某个条件值,然后能打印sum(对象.值)条件的1个...
基于0-1背包算法的社交网络行为隐写术 本文提出了一种基于0-1背包算法的社交网络行为隐写术,以解决传统隐写术的安全性问题。该方法通过引入0-1背包人员分配协议,降低了发送者和接收者有较多的共同好友这一限制...
**背包算法详解** 在计算机科学和算法设计中,背包问题是一种经典的优化问题,它源于组合优化和图论领域。背包问题通常与资源分配、决策分析和最优化策略相关,广泛应用于项目管理、库存控制、软件工程等多个领域。...
背包算法 背包算法JAVA实现 背包算法JAVA实现
Java背包算法规划求解是一种经典的优化问题,常用于解决资源有限条件下的最大化效益问题。在给定的场景中,我们有n种商品,每种商品只有一个,并且有200块钱去购物,目标是使购买的商品总价值最大。这个问题可以抽象...
【标题】"pack.rar_背包_背包算法_背包算法 MATLAB_背包算法MATLAB" 提供了一个关于使用MATLAB实现背包问题算法的详细资料。背包问题是一个经典的优化问题,广泛应用于资源分配、决策制定等领域。在这里,我们将深入...
三、价值背包算法 在本项目中,我们特别关注价值背包问题,即每个物品的价值和重量不等。在选择物品时,不仅考虑其重量,还要考虑其对整体价值的贡献。通过遗传算法,我们能够平衡重量限制与价值最大化的关系,找到...
C++编写的背包算法程序 cpp 动态规划
0-1背包算法的目的是在不超过背包总承重的情况下,选择物品以最大化总价值。 本文将详细介绍0-1背包问题的解决方案,并提供C++代码实现,以便读者理解并运行验证。 首先,我们需要定义物品的基本结构,包括其重量...
综合以上信息,我们可以了解到这是一套用C++编写的密码学程序,实现了背包算法,可能是为了加密或解密目的。要深入理解这个算法的工作原理和用途,我们需要查看`baglock.cpp`源代码,并结合密码学理论来分析其加密...
在IT领域,背包问题是一种经典的优化问题,常用于解决资源有限条件下的决策优化。这个问题源自于实际生活中的各种场景,...对于学生和爱好者而言,深入理解并熟练应用背包算法,无疑会增强他们在信息技术领域的竞争力。
用 PHP 实现的 01 背包算法,参考了网上的相关 C++ 算法,用来方便 PHP 程序员改造使用,我是用它来实现在指定宽度的栏中整齐的排列一堆标签云,效果非凡且神奇,初次使用时一瞬间的确有这样的感觉。
### 背包算法经典:深入解析背包九讲 #### 第一讲:01背包问题 **知识点概览**:01背包问题是最基础的背包问题类型,涉及到的每种物品仅有一件,且每件物品只能选择放入背包或不放入背包。此问题通过动态规划方法...
C++实现回溯算法 0 1 背包算法 本文将详细介绍 C++ 实现回溯算法 0 1 背包算法的知识点。 首先,需要了解背包问题的定义。背包问题是指在有限容量的背包中,如何选择物品以达到最大价值的优化问题。在这里,我们...
它描述的是这样的场景:我们有一组物品,每种物品都有一个重量和价值,我们需要选择一部分物品放入一个容量有限的背包中,使得放入背包的物品总重量不超过背包的容量,同时使这些物品的总价值最大。0-1背包问题的...
0-1背包问题和部分背包问题是运筹学和计算机科学中的经典优化问题,它们在资源分配、任务调度、投资决策等多个领域有广泛应用。本实验主要关注这两种问题的算法实现,特别是动态规划和贪心策略。 0-1背包问题源于一...
0-1背包问题是一种经典的组合优化问题,在计算机科学和运筹学中有着广泛的应用。...在实际编程中,可以使用Python、Java等编程语言实现这个算法,并通过输入不同的物品和背包承重,测试算法的正确性和效率。
【C++代码背包算法】 在计算机科学中,背包问题(Knapsack Problem)是一类经典的组合优化问题。它源于实际生活中的物品装箱问题,旨在确定如何选择物品以最大化价值,同时不超过容器(背包)的最大容量限制。背包...
输入物品数量n,报的容量m,每个物品的体积,每个物品的价值 输入:最大价值
01背包问题算法 动态规划 代码 01背包问题算法 动态规划 代码 01背包问题算法 动态规划 代码