当前位置: 首页 > news >正文

背包问题(java)实现

1、01背包



import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
       Scanner scan=new Scanner(System.in);
       int n=scan.nextInt();
       int m=scan.nextInt();
       int[][] dp=new int[n+1][m+1];
       int[] v=new int[n+1];
       int[] w=new int[n+1];
       for(int i=1;i<=n;i++) {
    	   v[i]=scan.nextInt();
    	   w[i]=scan.nextInt();
       }
       for(int i=1;i<=n;i++) {
    	   for(int j=1;j<=m;j++) {
    		   if(v[i]>j) {
    			   dp[i][j]=dp[i-1][j];
    		   }else {
    			   dp[i][j]=Math.max(dp[i-1][j],dp[i-1][j-v[i]]+w[i] );
    		   }
    	   }
       }
       System.out.println(dp[n][m]);
    
  }    
}

2、完全背包


import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
       Scanner scan=new Scanner(System.in);
       int n=scan.nextInt();
       int m=scan.nextInt();
       int[][] dp=new int[n+1][m+1];
       int[] v=new int[n+1];
       int[] w=new int[n+1];
       for(int i=1;i<=n;i++) {
    	   v[i]=scan.nextInt();
    	   w[i]=scan.nextInt();
       }
       for(int i=1;i<=n;i++) {
    	   for(int j=1;j<=m;j++) {
    		   dp[i][j]=dp[i-1][j];
    		   if(j>=v[i]) {
    			   dp[i][j]=Math.max(dp[i][j], dp[i][j-v[i]]+w[i]);
    		   }
       }
       
    
  }    
       System.out.println(dp[n][m]);

}
}

 3、多重背包1

数据范围 

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
       Scanner scan=new Scanner(System.in);
       int n=scan.nextInt();
       int m=scan.nextInt();
       int[][] dp=new int[n+1][m+1];
       int[] v=new int[n+1]; //体积
       int[] w=new int[n+1]; //价值
       int[] c=new int[n+1]; //重量
       for(int i=1;i<=n;i++) {
    	   v[i]=scan.nextInt();
    	   w[i]=scan.nextInt();
    	   c[i]=scan.nextInt();
       }
       for(int i=1;i<=n;i++) {
    	 for(int j=1;j<=m;j++) {
    		 dp[i][j]=dp[i-1][j];
    		 for(int k=1;k<=c[i]&&v[i]*k<=j;k++) {
    			 dp[i][j]=Math.max(dp[i][j], dp[i-1][j-v[i]*k]+w[i]*k);
    			 
    		 }
    		 System.out.print(dp[i][j]+" ");
    		 
    	 }
    	 System.out.println();
  }    
       System.out.println(dp[n][m]);

}
}

4、多重背包2

数据范围

import java.util.Scanner;
import java.util.ArrayList;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt(), m = in.nextInt();
        // 使用列表存储二进制优化后的物品
        int[] newV = new int[2000*11];
        int[] newW = new int[2000*11];
        int[] dp = new int[m + 1];
        int count = 0;

        // 二进制优化处理
        for (int i = 1; i <= n; i++) {
            int v = in.nextInt();
            int w = in.nextInt();
            int c = in.nextInt();

            // 二进制拆分(将数量c分解为1,2,4...的幂次方组合)
            for (int k = 1; k <= c; k *= 2) {
                newV[count]=(v * k);
                newW[count]=(w * k);
                c -= k;
                count++;
            }
            if (c > 0) {
                newV[count]=(v * c);
                newW[count]=(w * c);
                count++;
            }
        }

        // 转化为01背包问题
        for (int i = 0; i < count; i++) {
            // 01背包处理逻辑
            for (int j = m; j >= newV[i]; j--) {
                dp[j] = Math.max(dp[j], dp[j - newV[i]] + newW[i]);
            }
        }
        System.out.println(dp[m]);
    }
}

http://www.dtcms.com/a/123269.html

相关文章:

  • GPU通讯-基础篇
  • 跨境全域中台:前端独立站群+后端共享云仓的协同作战体系
  • 【云服务管理】
  • MySQL SQL Mode
  • Spring Boot MongoDB自定义连接池配置
  • 十分钟机器学习之--------------线性回归
  • 关于 Spring Boot 后端项目使用 Maven 打包命令、JAR/WAR 对比、内嵌服务器与第三方服务器对比,以及热部署配置的详细说明
  • 雷池WAF身份认证 - CAS
  • 数码视讯TR100系列/TR100-G1/TR100-G4/数码视讯F7-国科GK6323V100C芯片-刷机固件包
  • 如何优雅使用 ReentrantLock 进行加解锁:避免常见坑点,提高代码可维护性
  • ADI的BF561双核DSP怎么做开发,我来说一说(十一)NANDFLASH的读写
  • 十三届蓝桥杯Java省赛 B组(持续更新..)
  • YOLO 8 入坑(持续更新)
  • 【含文档+PPT+源码】基于Android家政服务系统的开发与实现
  • 【python】yield关键字的使用及执行步骤分析
  • HTTP 1.0 时代,第一次优化
  • antv x6使用(支持节点排序、新增节点、编辑节点、删除节点、选中节点)
  • ThinkpPHP生成二维码
  • 【C++初阶】--- vector容器功能模拟实现
  • STM32硬件IIC+DMA驱动OLED显示——释放CPU资源,提升实时性
  • Keras简介
  • AI 赋能 DBA:如何用 DeepSeek 等大模型简化数据库管理工作
  • 【每日随笔】丛林法则 ( 弱肉强食 | 适者生存 | 资源有限稀缺 | 没有道德约束 | 自发性与无序性 | 丛林法则映射 - 资源分配 与 社会分层 )
  • C++23新特性:显式对象形参与显式对象成员函数
  • Unity AssetBundle依赖树可视化分析工具开发指南
  • BeagleBone Black笔记
  • 传感器篇(二)——激光雷达
  • Prompt-to-prompt image editing with cross attention control
  • 网络通讯协议UDP转发TCP工具_UdpToTcpRelay_双向版
  • 蓝桥杯c ++笔记(含算法 贪心+动态规划+dp+进制转化+便利等)