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

思维+贪心,CF 1210B - Marcin and Training Camp

目录

一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

二、解题报告

1、思路分析

2、复杂度

3、代码详解


一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

1210B - Marcin and Training Camp


二、解题报告

1、思路分析

考虑一个数 x 不会比集合内所有数都强,可以注意到什么?

一定有一个数 y 满足 x & y = x

否则,x 和 每个数相比总有对方没有的,那么就没办法了

所以,我们先将所有 出现次数大于1 的数拿进集合(升序排序,去重即可)

然后遍历剩下的数字 x,如果集合中存在某个数字y 满足 x & y = x,我们就把x 拿进集合

2、复杂度

时间复杂度: O(nlogn)空间复杂度:O(n)

3、代码详解

 ​
#include <bits/stdc++.h>

// #define DEBUG

using u32 = unsigned;
using i64 = long long;
using u64 = unsigned long long;

constexpr int P = 1E9 + 7;
constexpr int inf32 = 1E9 + 7;
constexpr i64 inf64 = 1E18 + 7;

void solve() {
    int n;
    std::cin >> n;
    
    std::vector<i64> a(n);
    std::vector<int> b(n);
    for (int i = 0; i < n; ++ i) 
        std::cin >> a[i];    
    for (int i = 0; i < n; ++ i)
        std::cin >> b[i];

    i64 sum = 0;
    std::vector<int> id(n);
    std::iota(id.begin(), id.end(), 0);

    std::ranges::sort(id, [&a](int i, int j) -> bool {
        return a[i] < a[j];
    });

    std::vector<int> st, buf;

    for (int i = 0, j = 0; i < n; ) {
        i64 tot = 0;
        while (j < n && a[id[i]] == a[id[j]])
            tot += b[id[j ++]];
        if (j - i > 1) {
            sum += tot;
            st.insert(st.end(), id.begin() + i, id.begin() + j);
        }
        else {
            buf.insert(buf.end(), id.begin() + i, id.begin() + j);
        }
        i = j;
    }

    for (int i : buf) {
        bool ok = false;
        for (int j : st) {
            if ((a[i] & a[j]) == a[i]) {
                ok = true;
                break;
            }
        }
        if (ok) {
            st.push_back(i);
            sum += b[i];
        }
    }

    std::cout << sum;
}

int main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);

#ifdef DEBUG
    int cur = clock();
    freopen("in.txt", "r", stdin);
    freopen("out.txt", "w", stdout);
#endif

    int t = 1;
    // std::cin >> t;

    while (t--) {
        solve();
    }
#ifdef DEBUG
    std::cerr << "run-time: " << clock() - cur << '\n';
#endif
    return 0;
}


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

相关文章:

  • MySQL时间字段TIMESTAMP和DATETIME
  • CVE-2024-2961漏洞的简单学习
  • React Native 全栈开发实战班 - 数据管理与状态之Zustand应用
  • Go语言基本类型转换
  • InfluxDB时序数据库笔记(一)
  • Python爬虫下载新闻,Flask展现新闻(2)
  • SD-WebUI forge支持flux模型。算力互联forge镜像使用教程
  • 【鸿蒙学习】深入了解UIAbility组件
  • Java在用增强for循环遍历集合时删除元素,抛出java.util.ConcurrentModificationException异常
  • 【Verilog学习日常】—牛客网刷题—Verilog企业真题—VL69
  • 决策树中联合概率分布公式解释说明
  • 如何判断电器外壳是否带电
  • 十四、磁盘的管理
  • SpringBoot之Profile的两种使用方式
  • 二叉搜索树详解
  • 基于ARX结构的流密码算法Salsa20
  • mybatis-puls快速入门
  • Nginx的核心架构和设计原理
  • EnvoyFilter 是 Istio 中用于直接修改 Envoy 配置的一种资源类型
  • 帝都程序猿十二时辰
  • modelsim仿真 wave视图里 数据位宽和进制怎么显示
  • 通信工程学习:什么是CSMA/CD载波监听多路访问/冲突检测
  • 计算机知识科普问答--25(121-125)
  • 关于KKT条件的线性约束下非线性问题-MATLAB
  • 【机器学习】过拟合与欠拟合——如何优化模型性能
  • wx小程序中,商城订单详情显示还有多少分钟关闭