首页 > 编程语言 >一维资源分配问题(java实现)

一维资源分配问题(java实现)

时间:2023-07-19 22:55:05浏览次数:46  
标签:index java int max 投资额 profit static 一维 资源分配

一维资源分配

1.问题介绍


设有总量为a的某种原料,用于生产n种产品。假设用于生产第k种产品生产的数量为\(x_k\),并获得收益 \(\varphi(x_k)\),问应该如何分配n种产品的资源使用量使得总收益最大。


2.Solution


\(k\) : 生产第k种产品的决策阶段;
\(x_k\) : 投入到第k种产品生产的资源数;
\(s_k\) : 第k阶段开始时拥有的资源数量,则状态转移方程为 \(s_{k+1}= s_k - x_k\);
\(\varphi(x_k)\) : 生产第k种产品所获得的收益;
\(f_k(s_k)\) :从第k种产品开始一直到第n种产品生产完的最大总收益;

\[\begin{cases} f_k(s_k) = MAX_{0≤ x_k ≤ s_k}\left\{\varphi(x_k)+f_{k+1}(s_{k+1})\right\} \\\\ f_{n+1}(s_{n+1}) = 0 \end{cases} \]


3. Example

某企业现有资金 5000 万元准备对 A,B,C三个项目投资。假设对各项目的投资额只能取1000 万元的整数倍,各种情况下的利润 (单位: 万元) 如下表所示。问对三个项目的投资额各为多少时,总利润为最大?

投资额\项目 A B C
0 0 0 0
1 40 100 80
2 200 200 180
3 320 300 300
4 400 400 420
5 380 400 420

动态打表


image


image


image


Java实现

import java.io.*;
import java.util.*;

public class Main {
    static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
    static int N; // 投资额可选数
    static int P; // 项目数
    static int[][] profit; // 某种投资额数下某项目获利
    static int[][] profit_sum; // 某资金总数下只对某一项目采取某投资额的总利润
    static int[][] profit_max; // 存放每一个阶段下每一个资金总数下投资额的最优利润
    static ArrayList<ArrayList<ArrayList<Integer>>> best_X = new ArrayList<>(); // 存放最大利润对应投资额
    static int max; // 算最大利润时用

    public static void main(String[] args) throws IOException {
        // 读取投资额可选数和项目数
        String[] s = in.readLine().split(" ");
        N = Integer.parseInt(s[0]);
        P = Integer.parseInt(s[1]);
        
        profit = new int[N][P];
        profit_sum = new int[N][N];
        
        // 读取每个投资额数下每个项目的利润
        for (int i = 0; i < N; i++) {
            s = in.readLine().split(" ");
            for (int j = 0; j < P; j++)
                profit[i][j] = Integer.parseInt(s[j]);
        }
        
        profit_max = new int[N][N];
        // 调用ko()函数计算最优利润
        ko();
        
        System.out.println("得到最优分配方案:");
        // 递归打印出最优分配方案以及最大利润
        dfs(best_X.get(P-1).get(0), best_X.size()-1, "", N-1);
        System.out.println("最大利润:" + profit_max[0][N-1]);
    }

    private static void ko() {
        for (int k = P - 1; k >= 0; k--) {
            ArrayList<ArrayList<Integer>> pk = new ArrayList<>();
            best_X.add(pk);
            
            if (k == 0) {
                max = Integer.MIN_VALUE;
                // 计算最后一个阶段的投资额的利润和下一阶段资金总数的最优利润之和
                for (int x = 0; x < N; x++) {
                    profit_sum[N-1][x] = profit[x][k] + profit_max[k + 1][N - 1 - x];
                    max = Math.max(max, profit_sum[N-1][x]);
                }
                pk.add(new ArrayList<Integer>());
                for (int x = 0; x < N; x++) {
                    // 将最大利润对应的投资额添加到best_X中
                    if (max == profit_sum[N-1][x]) {
                        pk.get(0).add(x);
                    }
                }
                profit_max[k][N-1] = max;
            } else {
                for (int S = 0; S < N; S++) {
                    max = Integer.MIN_VALUE;
                    // 计算当前阶段下每个资金总数对应的投资额的总利润
                    for (int x = 0; x <= S; x++) {
                        profit_sum[S][x] = (k == P-1 ? profit[x][k] : (profit[x][k] + profit_max[k + 1][S - x]));
                        max = Math.max(max, profit_sum[S][x]);
                    }
                    // 将每个资金总数对应的最大利润的投资额添加到best_X中
                    addbest_x(max, S, pk);
                    profit_max[k][S] = max;
                }
            }
        }
    }

    private static void dfs(ArrayList<Integer> index_best, int flag, String res, int S) {
        if (flag == 0) {
            for (int index : index_best) {
                // 将找到的最优分配方案打印出来
                if (S - index == 0)
                    System.out.println("---> " + res + index);
            }
            return;
        }
        // 递归查找下一个阶段的最优分配方案
        for (int index : index_best) {
            dfs(best_X.get(flag - 1).get(S - index), flag - 1, res + index + " + ", S - index);
	}
   }
    private static void addbest_x(int max, int S, ArrayList<ArrayList<Integer>> pk) {
    pk.add(new ArrayList<Integer>());
    for (int x = 0; x < N; x++) {
        // 将最大利润对应的投资额添加到pk中
        if (max == profit_sum[S][x]) {
            pk.get(S).add(x);
        }
    }
   }
}

运行截图:

image


4. 总结:

写这个一开始挺困难的,当时很有感觉,但几天不看以后再看竟然看不懂了,其实就是找猫画虎的缘故,没有理解,自己目前也写不出这种方法,但我相信,念念不忘,必有回响!

标签:index,java,int,max,投资额,profit,static,一维,资源分配
From: https://www.cnblogs.com/Ly-abu/p/17566511.html

相关文章

  • 用java代码实现部门表,用户表的对应关系,把用户放到对应的部门下面
    实现如下所示: importjava.util.ArrayList;importjava.util.HashMap;importjava.util.List;importjava.util.Map;/***@author王立朝*@date2023/7/19*@description:*/publicclassTest2{publicstaticvoidmain(String[]args){//创建......
  • JavaScript学习笔记01(包含ES6语法)
    Js简介什么是Js?Js最初被创建的目的是“使网页更生动”。Js写出来的程序被称为脚本,Js是一门脚本语言。被直接写在网页的HTML中,在页面加载的时候自动执行脚本被以纯文本的形式提供和执行,不需要特殊的准备或编译即可运行(JINcompiler)Js不仅可以在浏览器中执行,也可以......
  • 【Azure Function App】Java Function部署到Azure后出现中文显示乱码问题
    问题描述JavaFunction在Azure上遇见中文显示乱码问题?如何解决呢? 问题解答中文字符显示为乱码,这个情况就是服务实例上设置的编码格式不是统一的UTF-8所导致的。在查看AzureAppService/FunctionApp的官方文档,都没有明确的说明它们使用的默认编码是什么,通过询问ChatGPT-4,也没有得......
  • Java基础语法(一)
    一、基本数据类型和String数据类型之间的运算(==注意:String是一个类,故而为引用数据类型==):1、String类的基本使用如下: Stringname="Wangyz"; System.out.println(name); //定义一个空的字符串 StringnullStr="";注意:String类和基本数据类型之间进行运算时只能进行连......
  • 【Azure Function App】Java Function部署到Azure后出现中文显示乱码问题
    问题描述JavaFunction在Azure上遇见中文显示乱码问题?如何解决呢? 问题解答中文字符显示为乱码,这个情况就是服务实例上设置的编码格式不是统一的UTF-8所导致的。在查看AzureAppService/FunctionApp的官方文档,都没有明确的说明它们使用的默认编码是什么,通过询问ChatGPT-4,也......
  • 根据表格生成java实体
    根据表格生成Java实体类在Java编程中,我们经常会遇到需要将表格中的数据映射到实体类的情况。这里我们来介绍一种常用的方法,即根据表格生成Java实体类。在开始之前,我们先来看一下表格的结构示例:字段名类型描述idint主键IDnameString姓名ageint年龄gende......
  • 根据url下载文件java后端
    根据URL下载文件的Java后端在开发Web应用程序时,经常需要从URL下载文件。Java后端使用URL连接和输入流可以轻松地实现文件下载功能。本文将介绍如何使用Java后端根据URL下载文件,并提供相应的代码示例。1.使用URL连接获取文件输入流使用Java的java.net包提供的URL类可以方便地与U......
  • 服务器上java项目数据库配置文件
    在服务器上配置Java项目数据库配置文件的流程概述在服务器上配置Java项目的数据库配置文件是非常重要的一步,它决定了项目与数据库的连接方式和相关配置信息。下面我将介绍整个配置流程,并附上相应的代码和注释,以便你能够顺利进行配置。配置步骤步骤操作1进入服务器......
  • 非java代码的微服务
    实现非Java代码的微服务简介微服务架构是一种将应用程序拆分成小的、独立的服务的方法。通常情况下,微服务被编写成多个不同的编程语言,以满足特定需求。在本文中,我将向你介绍如何实现非Java代码的微服务。流程概述下面是实现非Java代码的微服务的整体流程概述:步骤描述......
  • 大麦抢票 java
    大麦抢票Java简介大麦网是中国领先的综合性演出票务平台,为用户提供全面的票务信息和在线购票服务。而抢票则是指在演出票开售后,通过程序自动化的方式快速购买抢购热门演出票的过程。本文将介绍使用Java语言进行大麦抢票的实现方法。实现步骤1.登录大麦网首先,我们需要登录大......