防晒(0x07 贪心)

简介: 笔记

防晒


题意

有 C 头奶牛进行日光浴,第 i 头奶牛需要 minSPF[i] 到 maxSPF[i] 单位强度之间的阳光。


每头奶牛在日光浴前必须涂防晒霜,防晒霜有 L 种,涂上第 i 种之后,身体接收到的阳光强度就会稳定为 SPF[i],第 i 种防晒霜有 cover[i] 瓶。


求最多可以满足多少头奶牛进行日光浴。


思路

刚拿到这题的时候,我也不知道应该按什么顺序排序,但是我知道要么是按照 minSPF递增排序,要么是按照 maxSPF 递减排序。那么我们假设按照 maxSPF 递增排序。


如下图,有两头牛的 minSP 和 maxSPF 的范围和两种不同的防晒霜 x y46.png


那么我们应该把较大的 x 还是较小的 y 分配给第 i 头牛呢?


我们先假设 x 和 y 都可以分配给 第 i 头牛,因为我们是按照maxSPF递增排序的 所以第 i + 1头牛的maxSPF 一定大于等于第 i 头牛的maxSPF,那么值越大的防晒霜越有可能让更多的牛使用,所以当前第 i 头牛选择它能使用的值最小的防晒霜。


按照 minSPF递减排序也是一样的道理。


值越小的防晒霜越有可能让更多的牛使用,所以选择当前牛能选择的值最大的防晒霜。


代码

下面提供按照 maxSPF递增排序的参考代码。

#include<bits/stdc++.h>
#include<unordered_map>
// #define int long long
#define INF 0x3f3f3f3f
#define mod 1000000007
#define rep(i, st, ed) for (int (i) = (st); (i) <= (ed);++(i))
#define pre(i, ed, st) for (int (i) = (ed); (i) >= (st);--(i))
using namespace std;
typedef long long LL;
typedef pair<int, int> PII;
template<typename T> inline T gcd(T a, T b) { return b ? gcd(b, a % b) : a; }
template<typename T> inline T lowbit(T x) { return x & -x; }
const int N = 2600;
int c, L;
struct Node {
  int l, r;
  bool operator<(Node& x)const {
    return r < x.r;
  }
}node[N];
struct Node1 {
  int spf;
  int cover;
  bool operator<(Node1& x)const {
    return spf < x.spf;
  }
}node1[N];
void solve() {
  cin >> c >> L;
  for (int i = 1; i <= c; ++i) {
    cin >> node[i].l >> node[i].r;
  }
  for (int i = 1; i <= L; ++i) {
    cin >> node1[i].spf >> node1[i].cover;
  }
  sort(node + 1, node + 1 + c);
  sort(node1 + 1, node1 + 1 + L);
  int res = 0;
  for (int i = 1; i <= c; ++i) {
    for (int j = 1; j <= L; ++j) {
      if (node1[j].spf >= node[i].l && node1[j].spf <= node[i].r && node1[j].cover) {
        node1[j].cover--;
        res++;
        break;
      }
    }
  }
  cout << res << endl;
}
signed main() {
  // int t; cin >> t;
  // while (t--)
    solve();
  return 0;
}


目录
相关文章
|
机器学习/深度学习 搜索推荐 测试技术
【王喆-推荐系统】评估篇-(task2)推荐模型评估指标
准确率 (Accuracy) 是指分类正确的样本占总样本个数的比例。
2066 0
【王喆-推荐系统】评估篇-(task2)推荐模型评估指标
|
前端开发
前端ElementPlus框架中的几种图标按钮使用方式
本文介绍了如何在Element Plus前端框架中使用带有图标的按钮,包括设置按钮大小、图标大小、按钮类型以及如何为图标添加点击事件。
1458 0
|
SQL 网络协议 关系型数据库
【MySQL用法】在MySQL登录时出现Access denied for user ‘root‘@‘localhost‘ (using password: YES) 拒绝访问,并可修改MySQL密码
【MySQL用法】在MySQL登录时出现Access denied for user ‘root‘@‘localhost‘ (using password: YES) 拒绝访问,并可修改MySQL密码
4718 1
|
机器学习/深度学习 并行计算 搜索推荐
推荐系统总结(交替最小二乘法、LightFM、神经网络矩阵分解和神经协同过滤)
在社交媒体网络上,有大量的半结构化数据。该任务的数据集是从在线照片共享社交媒体网络 Flickr 收集的。Flickr 允许用户分享照片并相互交流(朋友)。目标是向访问此社交媒体平台的大量数据的每个用户推荐对象(图片)列表。训练数据集包含一组用于构建推荐系统的用户和项目(照片)之间的交互,包含评分基本事实的验证数据用于决定最终模型。除测试数据外,其余数据集不用于分析。
855 0
|
8天前
|
云安全 监控 安全
|
13天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1449 8
|
7天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
478 11