IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 牛客-HJ16-购物单 -> 正文阅读

[数据结构与算法]牛客-HJ16-购物单

题目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

思路

  1. 和背包问题的区别在于有无主附件
  2. 于是考虑每个物品时要考虑每种可能出现的情况,1、主件,2、主件+附件1,3、主件+附件2,4、主件+附件1+附件2
    可以看出一个商品(如果是主件的话)一共有四种情况 如果是附件的话就和普通一样

代码

import java.util.Vector;
import java.util.Scanner;
public class Main {
    public static <StringBuiler> void main(String[] args) {
        //记录运算符
        Scanner s = new Scanner(System.in);
        //总钱数
        int N = s.nextInt();
        //除个10 方便构建计算
        N=N/10;
        //希望购买的物品的总数
        int m = s.nextInt();
        //四种情况:1.主件 2.主件+附件1 3.主件+附件2 4.主件+附件1+附件2
        //为了将主附件连接起来 所以数组大小设置为3
        //用price存储各商品的价格数组 以allprice用来存储各商品的乘值
        int[][] price = new int[m][3];
        int[][] allprice = new int[m][3];
        //开始读取
        for(int i=0;i<m;i++){
            int a = s.nextInt()/10;
            int b = s.nextInt();
            int c = s.nextInt();
            //如果是主件的话
            if(c==0){
                price[i][0]=a;
                allprice[i][0]=a*b;
            }//如果是附件的话
            else{
                //判断是不是第二个附件 由于编号问题 所以c需要-1
                if(price[c-1][1]==0){
                    price[c-1][1] = a;
                    allprice[c-1][1] = a*b;
                }else{
                    price[c-1][2] = a;
                    allprice[c-1][2] = a*b;
                }
            }
        }
        //开始使用分组背包 创建dp背包 行为商品+1 列为总钱数+1
        int[][] dp = new int[m+1][N+1];
        //dp[i][j]的概念为从前i个主件中选取,奖金数量为j的情况下,所获得的最大价格*重要程度累加和
        //可知dp[0][i]=0 dp[i][0]也必为0 所以从1开始算
        for(int i=1;i<=m;++i){
            for(int j=1;j<=N;++j){
                //开始获取这个商品及其顺带的所有消息 如果它是附件的话其它为0 不影响
                int a = price[i-1][0], b = allprice[i-1][0]; //主1
                int c = price[i-1][1], d = allprice[i-1][1]; //辅1
                int e = price[i-1][2], f = allprice[i-1][2]; //辅2
                //开始进行连续的dp判断 如果可以把a塞进去的话
                dp[i][j] = j >= a ? Math.max(dp[i-1][j-a] + b, dp[i-1][j]) : dp[i-1][j];
                //如果可以把ab塞进去的话
                dp[i][j] = j>=(a+c) ? Math.max(dp[i-1][j-a-c]+b+d,dp[i][j]) : dp[i][j];
                dp[i][j] = j >= (a+e) ? Math.max(dp[i-1][j-a-e] + b + f, dp[i][j]) : dp[i][j];
                dp[i][j] = j >= (a+c+e) ? Math.max(dp[i-1][j-a-c-e] + b + d + f, dp[i][j]) : dp[i][j];
            }
        }
        System.out.print(dp[m][N] * 10);
        return ;
    }
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:47:47  更:2022-03-12 17:50:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 16:24:08-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码