问题描述

2363. 合并相似的物品 (Easy)

给你两个二维整数数组 items1items2 ,表示两个物品集合。每个数组 items 有以下特质:

  • items[i] = [valueᵢ, weightᵢ] 其中 valueᵢ 表示第 i 件物品的

    价值weightᵢ 表示第 i 件物品的 重量
  • items 中每件物品的价值都是 唯一的

请你返回一个二维数组 ret,其中 ret[i] = [valueᵢ, weightᵢ]weightᵢ

是所有价值为 valueᵢ 物品的 重量之和

注意: ret 应该按价值 升序 排序后返回。

示例 1:

  1. 输入:items1 = [[1,1],[4,5],[3,8]], items2 = [[3,1],[1,5]]
  2. 输出:[[1,6],[3,9],[4,5]]
  3. 解释:
  4. value = 1 的物品在 items1 weight = 1 ,在 items2 weight = 5
  5. ,总重量为 1 + 5 = 6
  6. value = 3 的物品再 items1 weight = 8 ,在 items2 weight = 1
  7. ,总重量为 8 + 1 = 9
  8. value = 4 的物品在 items1 weight = 5 ,总重量为 5
  9. 所以,我们返回 [[1,6],[3,9],[4,5]]

示例 2:

  1. 输入:items1 = [[1,1],[3,2],[2,3]], items2 =
  2. [[2,1],[3,2],[1,3]]
  3. 输出:[[1,4],[2,4],[3,4]]
  4. 解释:
  5. value = 1 的物品在 items1 weight = 1 ,在 items2 weight = 3
  6. ,总重量为 1 + 3 = 4
  7. value = 2 的物品在 items1 weight = 3 ,在 items2 weight = 1
  8. ,总重量为 3 + 1 = 4
  9. value = 3 的物品在 items1 weight = 2 ,在 items2 weight = 2
  10. ,总重量为 2 + 2 = 4
  11. 所以,我们返回 [[1,4],[2,4],[3,4]]

示例 3:

  1. 输入:items1 = [[1,3],[2,2]], items2 = [[7,1],[2,2],[1,4]]
  2. 输出:[[1,7],[2,4],[7,1]]
  3. 解释:
  4. value = 1 的物品在 items1 weight = 3 ,在 items2 weight = 4
  5. ,总重量为 3 + 4 = 7
  6. value = 2 的物品在 items1 weight = 2 ,在 items2 weight = 2
  7. ,总重量为 2 + 2 = 4
  8. value = 7 的物品在 items2 weight = 1 ,总重量为 1
  9. 所以,我们返回 [[1,7],[2,4],[7,1]]

提示:

  • 1 <= items1.length, items2.length <= 1000
  • items1[i].length == items2[i].length == 2
  • 1 <= valueᵢ, weightᵢ <= 1000
  • items1 中每个 valueᵢ 都是 唯一的
  • items2 中每个 valueᵢ 都是 唯一的

解题思路

哈希表+模拟

代码

  1. class Solution {
  2. public:
  3. vector<vector<int>> mergeSimilarItems(vector<vector<int>> &items1, vector<vector<int>> &items2) {
  4. unordered_map<int, int> ump;
  5. for (auto &vec : items1) {
  6. ump[vec[0]] += vec[1];
  7. }
  8. for (auto &vec : items2) {
  9. ump[vec[0]] += vec[1];
  10. }
  11. vector<vector<int>> ret;
  12. for (auto &pair : ump) {
  13. ret.push_back({pair.first, pair.second});
  14. }
  15. std::sort(ret.begin(), ret.end());
  16. return ret;
  17. }
  18. };

2363. 合并相似的物品 (Easy)的更多相关文章

  1. Java List集合排序

    二维 List 自定义排序 使用lambda表达式 import java.util.*; public class Main { public static void main(String[] a ...

  2. Java遍历Map集合

    Java遍历Map集合简单例子 import java.util.*; public class Main { public static void main(String[] args) { Has ...

  3. # HNOI2012 ~ HNOI2018 题解

    HNOI2012 题解 [HNOI2012]永无乡 Tag:线段树合并.启发式合并 联通块合并问题. 属于\(easy\)题,直接线段树合并 或 启发式合并即可. [HNOI2012]排队 Tag:组 ...

  4. ZOJ 3264 Present for MM

    寒假开始了···但是做题没有结束嘤··· 然后是dp专场嘤··· 题意:背包问题,给出背包容量和物品对数,每对物品都有特殊的关系:第一种关系是两个物品都取有价值,若只取一个则失去价值:第二种是两个物品 ...

  5. Luogu P1860 新魔法药水

    题目大意 具体题面及输入格式戳我! 商店里有\(N\)种药水,每种药水都有一个售价和回收价. 小\(S\) 攒了\(V\)元钱,还会\(M\)种魔法,可以把一些药水合成另一种药水. 他在第一天可以购买 ...

  6. 【LuoguP1273有线电视网】树形依赖背包

    参考论文http://wenku.baidu.com/view/8ab3daef5ef7ba0d4a733b25.html 参考一篇写的很好的博文http://www.cnblogs.com/GXZC ...

  7. WOJ 46 完全背包

    高级的暴力,神仙优化…… 首先$O(n^{3})$的$dp$很好想,然后这样可以$O(1)$地回答询问. 考虑到所有物品的体积是一个连续的区间,所以说我们可以合并一些物品来达到预处理时间均摊的效果. ...

  8. BZOJ 3227: [Sdoi2008]红黑树(tree)

    BZOJ 3227: [Sdoi2008]红黑树(tree) 标签(空格分隔): OI-BZOJ OI-其它 Time Limit: 10 Sec Memory Limit: 128 MB Descr ...

  9. 西安邀请赛-D(带权并查集+背包)

    题目链接:https://nanti.jisuanke.com/t/39271 题意:给定n个物品,m组限制,每个物品有个伤害值,现在让两个人取完所有物品,要使得两个人取得物品伤害值之和最接近,输出伤 ...

  10. 【DP】区间DP入门

    在开始之前我要感谢y总,是他精彩的讲解才让我对区间DP有较深的认识. 简介 一般是线性结构上的对区间进行求解最值,计数的动态规划.大致思路是枚举断点,然后对断点两边求取最优解,然后进行合并从而得解. ...

随机推荐

  1. VUE学习-条件渲染

    条件渲染 v-if & v-else-if & v-else <div id="app"> <h1 v-if="type == 'VUE ...

  2. Ubuntu磁盘查看分区和挂载

    1.查看硬盘 sudo lshw -c disk 查看有多少个硬盘,一般会显示 disk:0(设备名为 /dev/vda) disk:1 (设备名为 /dev/vdb) 2.查看分区 sudo fdi ...

  3. vue真实项目结构

    我明白你的需求.如果你想看一个真实企业项目使用的复杂目录结构,你可以参考以下几个例子: 根据1的介绍,一个vue项目的目录结构可以细分为以下几个部分: |- src | |- api 存放所有请求接口 ...

  4. vue双向数据绑定原理简单实现

    vue双向数据绑定原理实现 准备工作 ​ 新建一个index.js文件, 一个index.html文件 ​ index.js文件中, 定义Vue类, 并将Vue并称全局变量 window.Vue = ...

  5. .NET CORE-通过内置IOC容器IServiceCollection进行服务注册

    第一种方式: 在Startup中的ConfigureServices方法中注册服务: services.AddTransient<ITestServiceA, TestServiceA>( ...

  6. nginx转发tomcat之https不生效

    1.修改tomcat配置server.xml,让它从请求头中的X-Forwarded-Proto读取 <!-- xpath://Server/Service/Engine/Value --> ...

  7. K8S-kubeadm集群安装

    K8S-kubeadm集群安装 一.环境准备 1.服务器信息 2.系统初始(所有服务器) 2.1修改主机名 hostnamectl set-hostname <主机名> 2.2添加主机ho ...

  8. 【Java】@Scheduled注解各参数详解

    每隔5秒执行一次:*/5 * * * * ? 每隔1分钟执行一次:0 */1 * * * ? 每天23点执行一次:0 0 23 * * ? 每天凌晨1点执行一次:0 0 1 * * ? 每月1号凌晨1 ...

  9. Spring基本概述

    Spring是一个开源框架,官方网站是http://spring.io/,Spring是2003年兴起的一个轻量级的Java开发框架,由lnterface21公司的JavaEE专家RodJohnson ...

  10. 优化多if和else语句

    可以利用对象来进行映射 比如 let type = this.radio_value if (type === 'whole') { this.time_value = [] } else if (t ...