0-1背包问题蛮力法求解(java版本)
|
package BackPack;
public class Solves {
public int[] DecimaltoBinary(int n,int m)
{
int r;//求余数
int consult=1;//求商
int j = 0;
int []arr=new int[m];
while (consult!=0)
{
consult = n / 2;
r = n % 2;
n = consult;
arr[j] = r;
j++;
}
return arr;
}
/**
* 将求得的一位数组子集转换为二维数组
* @param m
* @return
*/
public int[][] Subset(int m)
{
Solves s=new Solves();
int subset[][]=new int[(int) Math.pow(2, m)][m];
for (int i = 0; i <Math.pow(2, m); i++)
{
for (int j =0; j<m; j++)
{
subset[i][j]=s.DecimaltoBinary(i,m)[j];
}
}
return subset;
}
public int MaxValue(int arr[])
{
int max = arr[0];
for (int in = 0 ; in < arr.length; in++)
{
if( arr[in] > max)
{
max = arr[in];
}
}
return max;
}
}
|
|
package BackPack;
import java.util.Scanner;
public class Demo {
public static void main(String[] args) {
// TODO Auto-generated method stub
int m;//物品的数量
int capacity;//背包的容量
int wb=0;//初始化背包的质量
int vb=0;//初始化背包的价值
Solves s=new Solves();
Scanner sc=new Scanner(System.in);
System.out.print("请输入物品的数量:");
m=sc.nextInt();
System.out.print("请输入背包的容量:");
capacity=sc.nextInt();
int weight[]=new int[m];//用来记录每个物品的重量
int value[]=new int[m];//用来记录每个物品的价值
for(int i=0;i<m;i++)
{
System.out.print("请输入物品"+i+"的重量:");
weight[i]=sc.nextInt();
System.out.print("请输入物品"+i+"的价值:");
value[i]=sc.nextInt();
}
int MaxValue[]=new int[(int)Math.pow(2, m)];
System.out.println("各个方案如下:");
for (int i = 0; i <Math.pow(2, m); i++)
{
for (int j =0; j<m; j++)
{
if(s.Subset(m)[i][j]==1)
{
wb+=weight[j]*s.Subset(m)[i][j];
vb+=value[j];
System.out.print("物品:"+j+"");
}
}
if(wb<=capacity)
{
MaxValue[i]=wb;
System.out.println("------"+"方案"+i+":总价值为:"+vb+" "+"总重量为:"+wb);
}
else
{
System.out.println("------"+"方案"+i+":超出背包容量!");
}
wb=0;
vb=0;
}
System.out.println("背包可装入的最大容量为:"+s.MaxValue(MaxValue));
}
}
|
0-1背包问题蛮力法求解(java版本)的更多相关文章
- 0-1背包问题蛮力法求解(c++版本)
// 0.1背包求解.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #define ...
- 0-1背包问题——回溯法求解【Python】
回溯法求解0-1背包问题: 问题:背包大小 w,物品个数 n,每个物品的重量与价值分别对应 w[i] 与 v[i],求放入背包中物品的总价值最大. 回溯法核心:能进则进,进不了则换,换不了则退.(按照 ...
- Java实现动态规划法求解0/1背包问题
摘要: 使用动态规划法求解0/1背包问题. 难度: 初级 0/1背包问题的动态规划法求解,前人之述备矣,这里所做的工作,不过是自己根据理解实现了一遍,主要目的还是锻炼思维和编程能力,同时,也是为了增进 ...
- 经典递归问题:0,1背包问题 kmp 用遗传算法来解背包问题,hash表,位图法搜索,最长公共子序列
0,1背包问题:我写笔记风格就是想到哪里写哪里,有很多是旧的也没删除,代码内部可能有很多重复的东西,但是保证能运行出最后效果 '''学点高大上的遗传算法''' '''首先是Np问题的定义: npc:多 ...
- linux ubuntu下如何安装并且切换java版本(Unsupported major.minor version 52.0)
最近在做一个dcos(数据中心操作系统)的东西,需要用marathon来做进程管理.遗憾的是0.6版本的marathon在API方面很是缺少,换成了0.15版本之后,运行时提示“Unsupported ...
- 蓝桥杯 0/1背包问题 (java)
今天第一次接触了0/1背包问题,总结一下,方便以后修改.不对的地方还请大家不啬赐教! 上一个蓝桥杯的例题: 数据规模和约定 代码: import java.util.Scanner; public ...
- 复利计算5.0(改成Java版本)与 单元测试
//由于C语言版本不方便单元测试,所以改成了java版本,部分代码如下:import java.util.Scanner; public class FuLi{ public static void ...
- Java版本:识别Json字符串并分隔成Map集合
前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...
- 你的程序支持复杂的时间调度嘛?如约而来的 java 版本
你的程序支持复杂的时间调度嘛? 这篇文章介绍了时间适配器的c#版本,是给客户端用的,服务器自然也要有一套对应的做法,java版本的 [年][月][日][星期][时间] [*][*][*][*][*] ...
随机推荐
- ASP.NET Core 中的那些认证中间件及一些重要知识点
前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...
- 一百元的智能家居——Asp.Net Mvc Api+讯飞语音+Android+Arduino
大半夜的,先说些废话提提神 如今智能家居已经不再停留在概念阶段,高大上的科技公司都已经推出了自己的部分或全套的智能家居解决方案,不过就目前的现状而言,大多还停留在展厅阶段,还没有广泛的推广起来,有人说 ...
- 异步编程 In .NET
概述 在之前写的一篇关于async和await的前世今生的文章之后,大家似乎在async和await提高网站处理能力方面还有一些疑问,博客园本身也做了不少的尝试.今天我们再来回答一下这个问题,同时我们 ...
- ExtJS 4.2 组件介绍
目录 1. 介绍 1.1 说明 1.2 组件分类 1.3 组件名称 1.4 组件结构 2. 组件的创建方式 2.1 Ext.create()创建 2.2 xtype创建 1. 介绍 1.1 说明 Ex ...
- Convert BSpline Curve to Arc Spline in OpenCASCADE
Convert BSpline Curve to Arc Spline in OpenCASCADE eryar@163.com Abstract. The paper based on OpenCA ...
- InnoDB体系结构学习笔记
后台线程 Master Thread 核心的后台线程,主要负责将缓冲池的数据异步刷新到磁盘,保证数据的一致性,包括(脏页的刷新).合并插入缓冲.(UNDO页的回收)等 IO Thread 4个writ ...
- Spring Quartz实现任务调度
任务调度 在企业级应用中,经常会制定一些"计划任务",即在某个时间点做某件事情 核心是以时间为关注点,即在一个特定的时间点,系统执行指定的一个操作 任务调度涉及多线程并发.线程池维 ...
- 机器指令翻译成 JavaScript —— No.5 指令变化
上一篇,我们通过内置解释器的方案,解决任意跳转的问题.同时,也提到另一个问题:如果指令发生变化,又该如何应对. 指令自改 如果指令加载到 RAM 中,那就和普通数据一样,也是可以随意修改的.然而,对应 ...
- 使用MonoTouch.Dialog简化iOS界面开发
MonoTouch.Dialog简称MT.D,是Xamarin.iOS的一个RAD工具包.它提供易于使用的声明式API,不需要使用导航控制器.表格等ViewController来定义复杂的应用程序UI ...
- MyBatis3:SQL映射
前言 前面学习了config.xml,下面就要进入MyBatis的核心SQL映射了,第一篇文章的时候,student.xml里面是这么写的: <?xml version="1.0&qu ...