随笔 - 531  文章 - 0  评论 - 3  阅读 - 10215 

 

贪心:按照 a[i] .y 递减排序, 对每个牛取 所有物品的值 最大的

复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=2504;
 struct T{
     int x,y;
 }a[N];
 int n,m,cnt[N],val[N];
 int ans=0;
 int cmp(T &a,T &b){
     return a.x>b.x;
 }
 int find(int x){
     int j,mx=0;
     for(int i=1;i<=m;i++){
         if(cnt[i]&&a[x].x<=val[i]&&a[x].y>=val[i]&&mx<val[i])
          mx=val[i],j=i;
     }
     if(mx) ans++,cnt[j]--;
 }
 signed main(){
     cin>>n>>m;
     int i;
     for(i=1;i<=n;i++) cin>>a[i].x>>a[i].y;
    for(i=1;i<=m;i++)cin>>val[i]>>cnt[i];
    sort(a+1,a+1+n,cmp);
    for(i=1;i<=n;i++)find(i);
    
    cout<<ans;
 }
 
 
 
复制代码

 

posted on   towboat  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示