传统题 1000ms 256MiB

数数真有趣

该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。

Counting is Fun!


给定两个整数 nnxx,请找出所有正整数三元组 (a,b,c)(a,b,c) 的数量,使得:

$$ab + ac + bc \le n \quad \text{并且} \quad a + b + c \le x. $$

其中,顺序不同的三元组视为不同(例如 (1,1,2)(1,1,2)(1,2,1)(1,2,1) 是不同的),并且 a,b,ca, b, c 都必须严格大于 00


输入

  • 第一行包含一个整数 tt1t1041 \le t \le 10^4),表示测试用例的数量。
  • 对于每个测试用例,包含两个整数 nnxx1n,x1061 \le n, x \le 10^6)。

保证所有测试用例中 nn 的总和不超过 10610^6,且 xx 的总和也不超过 10610^6


输出

对于每个测试用例,输出一个整数,表示满足 ab+ac+bcnab + ac + bc \le na+b+cxa + b + c \le x 的所有正整数三元组 (a,b,c)(a,b,c) 的数量。

输入输出样例 #1

输入 #1

4
7 4
10 5
7 1000
900000 400000

输出 #1

4
10
7
1768016938

说明

  • 在第一个测试用例中,满足条件的三元组为 (1,1,1)(1,1,1)(1,1,2)(1,1,2)(1,2,1)(1,2,1)(2,1,1)(2,1,1)。因此答案是 44
  • 在第二个测试用例中,满足条件的三元组为 (1,1,1)(1,1,1)(1,1,2)(1,1,2)(1,1,3)(1,1,3)(1,2,1)(1,2,1)(1,2,2)(1,2,2)(1,3,1)(1,3,1)(2,1,1)(2,1,1)(2,1,2)(2,1,2)(2,2,1)(2,2,1)(3,1,1)(3,1,1)。因此答案是 1010

【正式赛】第一届“红织码杯”程序设计竞赛

未参加
状态
已结束
规则
ACM/ICPC
题目
8
开始于
2025-3-9 13:00
结束于
2025-3-9 16:30
持续时间
3.5 小时
主持人
参赛人数
24