码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 487. 金明的预算方案


    Powered by:NEFU AB-IN

    Link

    文章目录

    • 487. 金明的预算方案
      • 题意
      • 思路
      • 代码

    487. 金明的预算方案

    • 题意

      略

    • 思路

      可以将每个主件及其附件看作一个物品组,记主件为 p,两个附件为 a,b,则最多一共有4种组合:
      这四种组合是互斥的,最多只能从中选一种,因此可以将每种组合看作一个物品,那么问题就变成了分组背包问题。可以参考 AcWing 9. 分组背包问题。
      在枚举四种组合时可以使用二进制的思想,可以简化代码。

      这里直接枚举的每个物品,以及是否带附属品的情况,利用分组背包的思想

    • 代码

      /*
      * @Author: NEFU AB-IN
      * @Date: 2023-09-07 15:45:41
      * @FilePath: \Acwing\487\487.cpp
      * @LastEditTime: 2023-09-07 15:47:51
      */
      #include 
      using namespace std;
      #define int long long
      #undef int
      
      #define SZ(X) ((int)(X).size())
      #define ALL(X) (X).begin(), (X).end()
      #define IOS                                                                                                            \
          ios::sync_with_stdio(false);                                                                                       \
          cin.tie(nullptr);                                                                                                  \
          cout.tie(nullptr)
      #define DEBUG(X) cout << #X << ": " << X << '\n'
      
      const int M = 70, N = 4e4 + 10, INF = 0x3f3f3f3f;
      
      struct sa
      {
          int v, sf; // 价格 满意度
      };
      
      int dp[N];
      int v[M], w[M], p[M];
      
      vector<int> g[M];
      vector<sa> W[M];
      
      signed main()
      {
          IOS;
      
          int n, m;
          cin >> n >> m;
      
          for (int i = 1; i <= m; ++i)
          {
              cin >> v[i] >> w[i] >> p[i];
              if (p[i] > 0)
              {
                  g[p[i]].push_back(i);
              }
          }
      
          for (int i = 1; i <= m; ++i)
          {
              if (!p[i])
              {
                  int dv = v[i], dsf = v[i] * w[i];
                  W[i].push_back({dv, dsf});
                  switch (SZ(g[i]))
                  {
                  case 0: {
                      break;
                  }
                  case 1: {
                      W[i].push_back({dv + v[g[i][0]], dsf + v[g[i][0]] * w[g[i][0]]});
                      break;
                  }
      
                  case 2: {
                      W[i].push_back({dv + v[g[i][0]], dsf + v[g[i][0]] * w[g[i][0]]});
                      W[i].push_back({dv + v[g[i][0]] + v[g[i][1]], dsf + v[g[i][0]] * w[g[i][0]] + v[g[i][1]] * w[g[i][1]]});
                      W[i].push_back({dv + v[g[i][1]], dsf + v[g[i][1]] * w[g[i][1]]});
                      break;
                  }
                  }
              }
          }
      
          for (int i = 1; i <= m; ++i)
          {
              if (p[i])
                  continue;
              for (int j = n; j >= 0; --j)
              {
                  for (auto st : W[i])
                  {
                      if (j - st.v >= 0)
                      {
                          dp[j] = max(dp[j], dp[j - st.v] + st.sf);
                      }
                  }
              }
          }
      
          cout << dp[n];
      
          return 0;
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
      • 46
      • 47
      • 48
      • 49
      • 50
      • 51
      • 52
      • 53
      • 54
      • 55
      • 56
      • 57
      • 58
      • 59
      • 60
      • 61
      • 62
      • 63
      • 64
      • 65
      • 66
      • 67
      • 68
      • 69
      • 70
      • 71
      • 72
      • 73
      • 74
      • 75
      • 76
      • 77
      • 78
      • 79
      • 80
      • 81
      • 82
      • 83
      • 84
      • 85
      • 86
      • 87
      • 88
      • 89
      • 90
      • 91
      • 92
      • 93
      • 94
  • 相关阅读:
    编程的简单实例,编程零基础入门教程,中文编程开发语言工具下载
    EXTJS 中grid 动态增加列的方法
    YOLO目标检测——PCB缺陷数据集下载分享【含对应voc、coco和yolo三种格式标签】
    机器学习 泰坦尼克号——灾难中的机器学习
    无线安全操作(1)
    Java面试题:线程池内“闹情绪”的线程,怎么办?
    Python学生公寓管理系统的设计与实现毕业设计源码181047
    C语言volatile关键字、内嵌汇编volatile与编译器的爱恨情仇
    dreamweaver家乡主题网页设计 DIV布局个人介绍网页模板代码 DW学生个人网站制作成品下载 HTML5期末大作业
    比selenium体验更好的ui自动化测试工具: cypress介绍
  • 原文地址:https://blog.csdn.net/qq_45859188/article/details/132739988
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号