蓝桥杯 XYZ

问题描述

给定一个区间 [L, R],请求出有多少组 (X, Y, Z) 满足:

in 复制代码
X + Y = Z

且满足:

in 复制代码
L ≤ X, Y, Z ≤ R

输入格式

本题包含多组询问。

  • 第一行包含一个整数 T,表示询问组数。
  • 接下来的 T 行,每行包含两个整数 Lᵢ, Rᵢ,用空格分隔,表示一组询问。

输出格式

输出 T 行,每行包含一个整数,表示满足条件的三元组 (X, Y, Z) 的组数。


样例输入

in 复制代码
2
1 3
1 4

样例输出

out 复制代码
3
6

样例说明

对于区间 [1, 3],满足条件的三元组有:

  • (1, 1, 2)
  • (1, 2, 3)
  • (2, 1, 3)

共 3 组。

对于区间 [1, 4],满足条件的三元组有:

  • (1, 1, 2)
  • (1, 2, 3)
  • (2, 1, 3)
  • (1, 3, 4)
  • (2, 2, 4)
  • (3, 1, 4)

共 6 组。


评测用例规模与约定

  • 对于 30% 的评测用例:T ≤ 1000Lᵢ, Rᵢ ≤ 100
  • 对于 100% 的评测用例:
    • 1 ≤ T ≤ 100000
    • 1 ≤ Lᵢ ≤ Rᵢ ≤ 10⁹

c++代码

cpp 复制代码
#include<bits/stdc++.h>
#include<stdio.h>

using namespace std;

typedef __int128_t ll;

int T, a, b;

ll getans(ll l, ll r) {
    if (2 * l > r) return 0;
    ll k = (ll)((r + 1) / 2);
    ll n = k - l + 1;
    ll mid = (r + 1) * n - 2 * l * n - n * (n - 1);
    mid *= 2;
    ll w = (ll)(r / 2);
    mid -= (w - l + 1);
    return mid;
}

int main() {
    cin >> T;
    while(T--) {
        cin >> a >> b;
        cout << (long long)getans(a, b) << endl;
    }
    return 0;
}//by wqs

思路解析

总的来说,这是一个数学找规律的题目,举几个例子,推导出数学规律就行

相关推荐
int型码农4 分钟前
数据结构第八章(二)-交换排序
c语言·数据结构·算法·排序算法
YKPG14 分钟前
C++学习-入门到精通【14】标准库算法
c++·学习·算法
zm14 分钟前
极限复习c++
开发语言·c++
CoovallyAIHub22 分钟前
AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别
深度学习·算法·计算机视觉
码农之王1 小时前
记录一次,利用AI DeepSeek,解决工作中算法和无限级树模型问题
后端·算法
程序猿本员1 小时前
线程池精华
c++·后端
靡樊1 小时前
Socket编程UDP\TCP
网络·c++·学习·tcp/ip·udp
·云扬·1 小时前
【PmHub面试篇】Gateway全局过滤器统计接口调用耗时面试要点解析
面试·职场和发展·gateway
byte轻骑兵2 小时前
【C++高级主题】命令空间(五):类、命名空间和作用域
开发语言·c++
忘梓.2 小时前
从二叉树到 STL:揭开 set 容器的本质与用法
开发语言·c++