天天看點

Magical Calendar CodeForces - 1371B rat1200

A competitive eater, Alice is scheduling some practices for an eating contest on a magical calendar. The calendar is unusual because a week contains not necessarily 7 days!

In detail, she can choose any integer k which satisfies 1≤k≤r, and set k days as the number of days in a week.

Alice is going to paint some n consecutive days on this calendar. On this calendar, dates are written from the left cell to the right cell in a week. If a date reaches the last day of a week, the next day’s cell is the leftmost cell in the next (under) row.

She wants to make all of the painted cells to be connected by side. It means, that for any two painted cells there should exist at least one sequence of painted cells, started in one of these cells, and ended in another, such that any two consecutive cells in this sequence are connected by side.

Alice is considering the shape of the painted cells. Two shapes are the same if there exists a way to make them exactly overlapped using only parallel moves, parallel to the calendar’s sides.

For example, in the picture, a week has 4 days and Alice paints 5 consecutive days. [1] and [2] are different shapes, but [1] and [3] are equal shapes.

Magical Calendar CodeForces - 1371B rat1200

Alice wants to know how many possible shapes exists if she set how many days a week has and choose consecutive n days and paints them in calendar started in one of the days of the week. As was said before, she considers only shapes, there all cells are connected by side.

Input

The input consists of multiple test cases. The first line contains a single integer t (1≤t≤1000) — the number of test cases. Next t lines contain descriptions of test cases.

For each test case, the only line contains two integers n, r (1≤n≤109,1≤r≤109).

Output

For each test case, print a single integer — the answer to the problem.

Please note, that the answer for some test cases won’t fit into 32-bit integer type, so you should use at least 64-bit integer type in your programming language.

Example

Input

5

3 4

3 2

3 1

13 7

1010000 9999999

Output

4

3

1

28

510049495001

Note

In the first test case, Alice can set 1,2,3 or 4 days as the number of days in a week.

There are 6 possible paintings shown in the picture, but there are only 4 different shapes. So, the answer is 4. Notice that the last example in the picture is an invalid painting because all cells are not connected by sides.

In the last test case, be careful with the overflow issue, described in the output format.

畫圖可以很清楚看出,與n與一行的天數有關

這裡放我的TLE做法,更簡潔明了,如何優化要自己去想想了=v=

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<iostream>
#include<algorithm>
#include<queue>
#include<map>
#include<cstdio>
#include<vector>
#include<set>
#include<cstring>
#include<cstdlib>
#include<time.h>
#include<stack>
#define INF 0x3f3f3f3f
using namespace std;
const int maxn=1e6+5;
typedef long long ll;
ll mod=10007;
ll num,f[maxn];
int main(){
    int t;
    scanf("%d",&t);
    while(t--){
        ll n,r;
        scanf("%lld%lld",&n,&r);
        ll sum=0;
        for(int i=1;i<=r;i++){
          if(n>i) sum+=i;
          else if(n==i){
            sum+=1;
            break;
          } 
        }
        printf("%lld\n",sum);
    }
  return 0;
}