D. Exam in MAC - 思维

题面

分析

可以计算出 0 0 0 到 c c c 之间所有的对数,一共有 c + 1 c + 1 c+1 个数,所以有(c + 1) * (c + 2) / 2 对。然后考虑什么情况可以导致出现不符合的情况:

  • 1.可能会存在 x + y x + y x+y 在集合中出现过的,那么对于集合中每一个元素 s i s_i si ,可以得出对于 0 ≤ x ≤ 0 \leq x \leq 0≤x≤ s i 2 {s_i}\over{2} 2si + 1 + 1 +1,每一个数都有另一个范围内的数存在对应,因此这部分都要减去。
  • 2.可能存在 y − x y - x y−x 在集合中出现过的, 那么对于集合中每一个元素 s i s_i si ,可以得出对于 s i ≤ y ≤ c s_i \leq y \leq c si≤y≤c,每一个数都有另一个范围内的数存在对应,因此这部分都要减去。
  • 3.以上两部分减去了一部分重复的,也就是 x + y x + y x+y 和 y − x y - x y−x 同时在集合中的,所以要将这两部分加起来,设 x + y = s i x + y = s_i x+y=si, y − x = s j y - x = s_j y−x=sj,那么解方程可以得到 x x x = s i − s j 2 {s_i - s_j}\over{2} 2si−sj, y y y = s i + s j 2 {s_i + s_j}\over{2} 2si+sj,那么如果 s i 和 s j s_i和s_j si和sj的奇偶性不一样,那么 x 和 y x 和 y x和y就不是整数,说明不存在,其他情况存在。
代码
cpp 复制代码
#include <bits/stdc++.h>

using namespace std;
using ll = long long;

void solve() {
    int n;
    ll c;
    cin >> n >> c;
    vector<ll> x(n);
    for(int i = 0; i < n; i ++) cin >> x[i];
    ll ans = (c + 1) * (c + 2) / 2;
    int cnt1 = 0, cnt2 = 0;
    for(int i = 0; i < n; i ++) {
        ans -= x[i] / 2 + 1;
        ans -= c - x[i] + 1;
        if(x[i] & 1) cnt1 ++;
        else cnt2 ++;
    }
    ans += (ll)cnt1 * (cnt1 + 1) / 2;
    ans += (ll)cnt2 * (cnt2 + 1) / 2;
    cout << ans << "\n";
}

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

    int T;
    cin >> T;
    while(T --) {
        solve();
    }
}
相关推荐
Galerkin码农选手1 分钟前
awq_marlin和gptq_marlin量化算法简要介绍
算法
buhuizhiyuci1 分钟前
【算法篇】动态规划——斐波那契数列模型
算法·动态规划
牟师傅敲代码2 分钟前
第2章:底层时间驱动机制
c++
棱镜研途3 分钟前
学习笔记丨模式识别与机器学习5大核心赛道解析(IC-IPPR 2026)
人工智能·神经网络·算法·机器学习·模式识别·学术会议·智能计算
SuperHeroWu713 分钟前
【算法】逻辑回归虽然名字中有“回归“,但通常用于二分类任务。如何理解学习?
算法·回归·逻辑回归·二分类任务
gCode Teacher 格码致知16 分钟前
Python教学:十六进制编码的显示方法-由Deepseek产生
开发语言·python·算法
05候补工程师17 分钟前
【408数据结构】核心考点:图(Graph)精炼笔记与算法直觉
数据结构·经验分享·笔记·考研·算法·图论
并不喜欢吃鱼17 分钟前
从零开始 C++------ 十四【C++ 数据结构】unordered_map/unordered_set 全解析:从使用到底层模拟实现
开发语言·数据结构·c++
靠沿17 分钟前
【动态规划算法】专题三——简单多状态dp问题
算法·动态规划
吃好睡好便好19 分钟前
矩阵秩的计算
人工智能·学习·线性代数·算法·机器学习·matlab·矩阵