-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathB.cpp
43 lines (31 loc) · 1.58 KB
/
B.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#include <bits/stdc++.h>
using namespace std;
#ifndef HELLO_PEOPLE
#define cerr if(0) cout
#endif
using ll = long long;
using ld = long double;
#define all(v) (v).begin(), (v).end()
#define X first
#define Y second
// magic
template<class T> struct Nit { T _v, _s; Nit(T v, T s) : _v(v), _s(s) {} operator T &() { return _v; } T operator *() const { return _v; } Nit &operator++() { _v += _s; return *this; } bool operator!=(Nit &a) { return (_s > 0 ? _v < a._v : _v >= a._v); } }; template<class T = int> struct range { T _b, _e, _s; range(T e) : _b(0), _e(e), _s(1) {} range(T b, T e, T s = 1) : _b(b), _e(e), _s(s) {} Nit<T> begin() { return Nit<T>(_b, _s); } Nit<T> end() { return Nit<T>(_e, _s); } }; template<class T = int> struct rrange : range<T> { rrange(T e, T b, T s = 1) : range<T>(e, b, -s) {} rrange(T e) : range<T>(e, 0, -1) {} }; template<int D, class T> struct vec : public vector<vec<D - 1, T>> { template<class... Args> vec(int n = 0, Args... a) : vector<vec<D - 1, T>>(n, vec<D - 1, T>(a...)) {} }; template<class T> struct vec<1, T> : public vector<T> { vec(int n = 0, T const &val = T()) : vector<T>(n, val) {} };
// now start
ll constexpr INF = 1e14;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
auto &&run_case = []() {
ll n, r;
cin >> n >> r;
auto &&sum = [](ll a) -> ll { return (a * (a + 1)) / 2; };
ll ans = 0;
ans += sum(min(r, n - 1));
if (r >= n) ans++;
cout << ans << '\n';
};
int tc;
cin >> tc;
while (tc--) run_case();
return 0;
}