2025-10-03 HETAO CSP-S复赛集训营模拟赛-002 总结 Ⅱ

B.rmtcg

原题链接:rmtcg - 核桃OJ

代码这不就来了吗?

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 300005, V = 1000005, pi = 79498 + 5; //N是输入的空间大小,V是值域,pi是1~1e6的质数个数
unsigned bit_width(unsigned x){
    return x == 0 ? 0 : floor(log2(x)) + 1;
}
int n, m, a[N], st[21][N];
vector<int> d[V];
vector<int> pos[pi];
vector<int> primes;
vector<int> id;
int l, r, k;
int main(){
    freopen("rmtcg.in", "r", stdin);
    freopen("rmtcg.out", "w", stdout);
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    cin >> n >> m;
    for (int i = 0; i < n; i++){
        cin >> a[i];
    }
    int o = bit_width(n); //获取n的二进制位数
    for (int i = 0; i < n; i++){
        st[0][i] = a[i];
    }
    for (int i = 1; i < o; i++){
        for (int j = 0; j + (1 << i) <= n; j++){
            st[i][j] = __gcd(st[i - 1][j], st[i - 1][j + (1 << (i - 1))]);
        }
    }
    auto rangegcd = [&](int l, int r){ //获得区间的gcd
        int L = bit_width(unsigned(r - l + 1)) - 1;
        return __gcd(st[L][l], st[L][r - (1 << L) + 1]);
    };
    // 修改开始:添加了id向量的初始化
    id.resize(V); // 添加这一行来初始化id向量的大小
    for (int i = 2; i < V; i++){
        if (d[i].empty()){
            id[i] = primes.size();
            primes.push_back(i);
            for (int j = i; j < V; j += i){
                d[j].push_back(i);
            }
        }
    }
    for (int i = 0; i < n; i++){
        for (auto p : d[a[i]])
            pos[id[p]].push_back(i);
    }
    while (m--){
        cin >> l >> r >> k;
        l--; //下标从0开始,做-1
        r--;
        k--;
        int D = rangegcd(l, r);
        if (D % primes[k] == 0){ 
            cout << (D != primes[k]) << '\n';
            continue;
        }
        int ans = r - l + 1;
        ans -= upper_bound(pos[k].begin(), pos[k].end(), r) - lower_bound(pos[k].begin(), pos[k].end(), l);
        cout << ans << '\n';
    }
}

官方题解代码真是漏洞百出,居然在C++14中CE。

相关推荐
ajassi20002 小时前
开源 C++ QT QML 开发(四)复杂控件--Listview
c++·qt·开源
Vect__2 小时前
二叉树实战笔记:结构、遍历、接口与 OJ 实战
数据结构·c++·算法
青草地溪水旁2 小时前
第六章:适配器模式 - 接口转换的艺术大师
c++·适配器模式
charlie1145141913 小时前
精读C++20设计模式——结构型设计模式:外观模式
c++·学习·设计模式·c++20·外观模式
奔跑吧邓邓子4 小时前
【C++实战(58)】解锁C++内存优化密码:从泄漏检测到完美修复
c++·实战·内存优化
liulilittle4 小时前
macOS 内核路由表操作:直接 API 编程指南
网络·c++·macos·策略模式·路由·route·通信
辞旧 lekkk4 小时前
【c++】初识STL和string类
开发语言·c++·学习·萌新
爱和冰阔落5 小时前
【C++ STL栈和队列下】deque(双端队列) 优先级队列的模拟实现与仿函数的介绍
开发语言·数据结构·c++·算法·广度优先
想唱rap5 小时前
C++类和对象(2)
开发语言·c++·笔记·算法·新浪微博