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

思路解析

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

相关推荐
跳跳糖炒酸奶5 分钟前
第四章、Isaacsim在GUI中构建机器人(2):组装一个简单的机器人
人工智能·python·算法·ubuntu·机器人
绵绵细雨中的乡音20 分钟前
动态规划-第六篇
算法·动态规划
程序员黄同学29 分钟前
动态规划,如何应用动态规划解决实际问题?
算法·动态规划
march_birds1 小时前
FreeRTOS 与 RT-Thread 事件组对比分析
c语言·单片机·算法·系统架构
斯汤雷1 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化
Jasmin Tin Wei2 小时前
蓝桥杯 web 学海无涯(axios、ecahrts)版本二
前端·蓝桥杯
云 无 心 以 出 岫2 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
渗透测试老鸟-九青2 小时前
面试经验分享 | 成都渗透测试工程师二面面经分享
服务器·经验分享·安全·web安全·面试·职场和发展·区块链
俏布斯2 小时前
算法日常记录
java·算法·leetcode
独好紫罗兰2 小时前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法