P10416 [蓝桥杯 2023 国 A] XYZ

P10416 [蓝桥杯 2023 国 A] XYZ

题目描述

给定一个区间 [ L , R ] [L,R] [L,R],请求出有多少组 X , Y , Z X,Y,Z X,Y,Z 满足 X + Y = Z X+Y=Z X+Y=Z 且 L ≤ X , Y , Z ≤ R L\le X,Y,Z\le R L≤X,Y,Z≤R。

输入格式

本题包含多组询问。

输入的第一行包含一个整数 T T T 表示询问组数。

接下来 T T T 行,每行包含两个整数 L i , R i L_i,R_i Li,Ri,用一个空格分隔,表示一组询问。

输出格式

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

输入输出样例 #1

输入 #1

复制代码
2
1 3
1 4

输出 #1

复制代码
3
6

说明/提示

【样例解释 1】

1 + 1 = 2 1+1=2 1+1=2
1 + 2 = 3 1+2=3 1+2=3
2 + 1 = 3 2+1=3 2+1=3
1 + 3 = 4 1+3=4 1+3=4
2 + 2 = 4 2+2=4 2+2=4
3 + 1 = 4 3+1=4 3+1=4

【评测用例规模与约定】

对于 30 % 30\% 30% 的评测用例, T ≤ 1000 T\le 1000 T≤1000, L i , R i ≤ 100 L_i,R_i\le 100 Li,Ri≤100。

对于所有评测用例, 1 ≤ T ≤ 100000 1\le T\le 100000 1≤T≤100000, 1 ≤ L i ≤ R i ≤ 1 0 9 1\le L_i\le R_i\le 10^9 1≤Li≤Ri≤109。

x和y从L开始,那么z从2L开始,依次加1可以发现规律,这是一个等差数列,1+2+3+⋯+(R−2L+1)

和为(R−2L+1)×(R−2L+2)/2

cpp 复制代码
#include<bits/stdc++.h> 
using namespace std;  

int main()
{
    long long ans,t;
    cin >> t; 
    while(t--)
    {
        long long l,r,n,m;
        cin >> l >> r; 
        if(r<2*l)
        {
            cout << 0 << endl; 
            continue; 
        }
        n=r-2*l+1;
        m=r-2*l+2;
        ans=n*m/2;
        // 输出答案
        cout << ans << endl;  
    }
    return 0; 
}
相关推荐
YuforiaCode25 分钟前
第十四届蓝桥杯 2023 C/C++组 平方差
c语言·c++·蓝桥杯
慕容青峰1 小时前
【蓝桥杯 2025 省 A 扫地机器人】题解
c++·算法·蓝桥杯·sublime text
_yingty_1 小时前
GO语言入门:常用数学函数2
java·学习·算法·golang
猎猎长风1 小时前
【数据结构和算法】3. 排序算法
数据结构·算法·排序算法
玩转数据库管理工具FOR DBLENS2 小时前
项目预期管理:超越甘特图,实现客户价值交付
数据库·职场和发展·项目管理·产品经理·数据库开发·甘特图
bookish_2010_prj2 小时前
链式栈和线性栈
数据结构·c++·算法
egoist20232 小时前
【C++指南】哈希驱动的封装:如何让unordered_map/set飞得更快更稳?【上】
数据结构·c++·算法·容器·哈希算法·散列表·c++11
Wang201220132 小时前
随机深林算法是分类还是回归?
算法·分类·回归
@蓝莓果粒茶2 小时前
LeetCode第158题_用Read4读取N个字符 II
前端·c++·python·算法·leetcode·职场和发展·c#
Heisenberg~2 小时前
C++回溯算法详解
开发语言·c++·算法