D - New Year‘s Problem

Problem - D - Codeforces

题目大意:m个商店,n个朋友,要向朋友送礼物,限制是只能在n-1个商店内为n个朋友选择礼物。每个礼物对不同的朋友有不同的开心值。矩阵M[i, j]表示第i个商店对第j个朋友的开心值(如果选的话。现在要求最大的每个朋友的最小开心值。

解题思路:最小值最大,二分答案,二分开心值。如果进行check?发现如果这个二分值可以那么一定满足:

  • 每个朋友在不同的商店中都存在一个大于等于mid的开心值
  • 由于n个朋友要去n-1个商店,因此一定有一个商店给两个朋友买了礼物。因此,一定存在一个商店有大于等于2个开心值是大于等于mid的

根据以上进行即可。

n * m <= 1e5直接开数组会TLE,以下是解决方案:

vector

注意:**n * m <= 1e5 **,可以用vector动态开。

cpp 复制代码
vector<vector<int>> a(n,vector<int>(m)); // n * m
vector<vector<int>> a(m, vector<int>(n)); // m * n
二维压缩为一维

M[i, j]可以用以下进行表示

cpp 复制代码
const int N = 2e5 + 21;
a[N];
a[(i-1)*n+j]; // i * j

代码:

cpp 复制代码
void solve() {
    int m,n; cin>>m>>n;
    // 按照朋友序号存入各个商店的开心值
    // 初始多加一个0,表示如果不可能时,那么就是0
    vector<vector<int>> a(n, {0});
    for(int i = 0; i < m; ++i) {
        for(int j = 0; j < n; ++j) {
            int t; cin>>t;
            a[j].push_back(t);
        }
    }
    auto check = [&](int mid) -> bool {
        // 先判断是否每个朋友都存在开心值大于等于mid的
        for(int i = 0; i < n; ++i) {
            bool ok = false;
            for(int j = 0; j <= m; ++j) ok |= a[i][j] >= mid;
            if(!ok) return false; 
        }
        // 再判断是否存在一个商店存在开心值大于等于mid的个数大于1
        for(int i = 0; i <= m; ++i) {
            int cnt = 0;
            for(int j = 0; j < n; ++j) cnt += a[j][i] >= mid;
            if(cnt >= 2) return true;
        }
        return false;
    };
    // 最小值最大模板
    int l = 0, r = 1e9 + 21;
    while(l < r) {
        int mid = l + r + 1 >> 1;
        if(check(mid)) l = mid;
        else r = mid - 1;
    }
    cout<<l<<'\n';
}

CF1619D New Year's Problem - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

相关推荐
CoovallyAIHub2 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub2 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub2 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙2 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
CoovallyAIHub6 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库6 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语07166 小时前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法
哈里谢顿21 小时前
跳表(Skip List):简单高效的有序数据结构
数据结构
CoovallyAIHub1 天前
181小时视频丢给GPT-5,准确率只有15%——南大联合NVIDIA等五校发布多模态终身理解数据集
深度学习·算法·计算机视觉