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

lanqiaoOJ 3744:小蓝的智慧拼图购物 ← pair+优先队列

【题目来源】
https://www.lanqiao.cn/problems/3744/learning/

【题目描述】
在小蓝的生日那天,他得到了一个由神秘人赠送的拼图游戏,每个拼图都有其特定的价值和相应的优惠券。小蓝决定要买下所有的拼图,但他希望能尽可能地节省花费。小蓝手中有 N 个拼图,每个拼图的价格不同,第 i 个拼图的价格为 Pi。同时,他有 M 张优惠券,每张优惠券都有其特定的使用条件:只有当拼图的价格至少为 Li 时,他才能使用这张优惠券,并且可以享受 Di 的折扣。每张优惠券只能使用一次,且
同一件拼图不能同时使用多张优惠券。如果某件拼图没有使用优惠券,则需要按照其标价购买。请你帮助小蓝计算出购买所有拼图所需的最少金额。

【输入格式】
第一行输入两个整数 N 和 M,分别表示拼图的数量和优惠券的数量。
接下来一行读入 N 个整数 P1,P2,…,Pn,表示每个
拼图的价格
接下来一行读入 M 个整数 L1,L2,…,Lm,表示每个
优惠卷的使用门槛
接下来一行读入 M 个整数 D1,D2,…,Dm,表示每个
优惠卷的折扣
数据范围保证:1≤N, M≤2×10^5,1≤Pi≤1
0^9,1≤Di≤Li10^9

【输出格式】
输出一个整数,表示购买所有拼图所需的
最少金额。

【输入样例】
2 5
12 8
5 11 5 11 10
3 9 1 3 2

【输出样例】
8

【算法分析】
● 注意“同一件拼图不能同时使用多张优惠券”,也要明确“优惠券使用后就不存在了”。
● 本题使用大根堆:
priority_queue<int,vector<int>,less<int>> pq;

【算法代码】

#include <bits/stdc++.h>
using namespace std;

const int maxn=2e5+5;
int p[maxn];
pair<int,int> tkt[maxn];
priority_queue<int,vector<int>,less<int>> pq;
long long ans=0;

int main() {
    int n,m;
    cin>>n>>m;
    for(int i=0; i<n; i++) cin>>p[i];
    for(int i=0; i<m; i++) cin>>tkt[i].first;
    for(int i=0; i<m; i++) cin>>tkt[i].second;

    sort(p,p+n); //small to big
    sort(tkt,tkt+m); //small to big

    int cnt=0;
    for(int i=0; i<n; i++) {
        while(p[i]>=tkt[cnt].first && cnt<m) {
            pq.push(tkt[cnt].second);
            cnt++;
        }
        if(!pq.empty()) {
            ans+=p[i]-pq.top();
            pq.pop();
        } else ans+=p[i];
    }
    cout << ans;

    return 0;
}


/*
in1:
2 5
12 8
5 11 5 11 10
3 9 1 3 2

out1:
8
------------
in2:
1 2
9
10 9
10 3

out2:
6
*/





【参考文献】
https://www.lanqiao.cn/problems/3744/learning/





 


http://www.kler.cn/a/429009.html

相关文章:

  • 第5章:Python TDD定义Dollar对象相等性
  • 记录node-sass无法安装的问题
  • 微服务入门:从零开始构建你的微服务架构
  • python爬虫报错日记
  • 第22篇 基于ARM A9处理器用汇编语言实现中断<四>
  • [MySQL | 二、基本数据类型]
  • Origin快速拟合荧光寿命、PL Decay (TRPL)数据分析处理-方法二
  • Apache Solr 身份认证绕过漏洞复现(CVE-2024-45216)
  • MySQL系列之数据授权(安全)
  • 前端导出excel实战(xlsx库和exceljs库)
  • Leetcode 739-每日温度
  • Docker容器网络与通信
  • mysql备份数据库
  • 8.16DEBUG——DOCKER相关,DOCKER启动异常
  • Python-分析内存进制转换
  • HOC vs Render Props vs Hooks
  • 在Windows下C语言获取当前应用程序运行路径并获取指定目录下所有文件(包括子目录)
  • 决策树:ID3、C4.5和CART特征选择方式
  • Lua使用点号和冒号的区别
  • Selenium是广泛使用的模拟浏览器运行的库
  • 为超越JVM而生?深入理解Kotlin Native的梦想与可能
  • 使用PaddleOCR遇到的问题Bug
  • 机器学习:全面学习路径指南
  • 漫画之家Spring Boot:漫画资源的跨设备访问
  • photoblog解题过程
  • 代码随想录第五十一天