蓝桥杯 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

思路解析

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

相关推荐
一只侯子17 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
Cinema KI17 小时前
吃透C++继承:不止是代码复用,更是面向对象设计的底层思维
c++
jianqiang.xue17 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈17 小时前
Python数据结构
数据结构·算法·排序算法
J***793918 小时前
后端在分布式系统中的数据分片
算法·哈希算法
天真小巫18 小时前
2025.11.28总结
职场和发展
Dream it possible!19 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试
sin_hielo20 小时前
leetcode 2872
数据结构·算法·leetcode
dragoooon3420 小时前
[优选算法专题八.分治-归并 ——NO.49 翻转对]
算法
AI科技星20 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法