Educational Codeforces Round 34 (Rated for Div. 2) D
D. Almost Difference
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard outputLet's denote a function
You are given an array a consisting of n integers. You have to calculate the sum of d(ai, aj) over all pairs (i, j) such that 1 ≤ i ≤ j ≤ n.
Input
The first line contains one integer n (1 ≤ n ≤ 200000) — the number of elements in a.
The second line contains n integers a1, a2, ..., an (1 ≤ ai ≤ 109) — elements of the array.
Output
Print one integer — the sum of d(ai, aj) over all pairs (i, j) such that 1 ≤ i ≤ j ≤ n.
Examples
input
5 1 2 3 1 3
output
4
input
4 6 6 5 5
output
0
input
4 6 6 4 4
output
-8
Note
In the first example:
- d(a1, a2) = 0;
- d(a1, a3) = 2;
- d(a1, a4) = 0;
- d(a1, a5) = 2;
- d(a2, a3) = 0;
- d(a2, a4) = 0;
- d(a2, a5) = 0;
- d(a3, a4) = - 2;
- d(a3, a5) = 0;
- d(a4, a5) = 2.
此題爆了long long(9*1e18),可以考慮用long double儲存,輸出用%Lf,但需要在C++14下才可以
考慮每個數對答案的貢獻,即被當做x和y的次數,然後再處理一下特殊的情況即可
蠢哭了
看了一天
#include<bits/stdc++.h>
using namespace std;
#define maxn 200000+1000
#define LL long long
long long a[maxn];
map<long long,int>q;
int main(){
int n;
cin>>n;
long double sum=0;
for(int j=1;j<=n;j++){
cin>>a[j];
sum+=(j-1)*a[j];
sum-=(n-j)*a[j];
}
for(int j=1;j<=n;j++){
q[a[j]]++;
sum-=q[a[j]-1];
sum+=q[a[j]+1];
}
printf("%.0Lf\n",sum);
}
//-9999999990000000000 longlong 爆這組
相關文章
- Educational Codeforces Round 170 (Rated for Div. 2) A-D
- Educational Codeforces Round 142 (Rated for Div. 2) A-D
- Educational Codeforces Round 154 (Rated for Div. 2)
- Educational Codeforces Round 163 (Rated for Div. 2)
- Educational Codeforces Round 93 (Rated for Div. 2)
- Educational Codeforces Round 37 (Rated for Div. 2)
- Educational Codeforces Round 170 (Rated for Div. 2)
- Educational Codeforces Round 168 (Rated for Div. 2)
- Educational Codeforces Round 172 (Rated for Div. 2)
- Educational Codeforces Round 100 (Rated for Div. 2)
- Educational Codeforces Round 167 (Rated for Div. 2) D(dp,貪心)
- Educational Codeforces Round 99 (Rated for Div. 2)D. Sequence and Swaps
- Educational Codeforces Round 168 (Rated for Div. 2) A - E
- Educational Codeforces Round 170 (Rated for Div. 2) ABCD
- Educational Codeforces Round 172 (Rated for Div. 2)題解記錄(A~D)
- Educational Codeforces Round 93 (Rated for Div. 2)題解
- vp Educational Codeforces Round 168 (Rated for Div. 2) A - E
- Educational Codeforces Round 168 (Rated for Div. 2) 題解
- Educational Codeforces Round 171 (Rated for Div. 2) 題解
- Educational Codeforces Round 143 (Rated for Div. 2) A-E
- Educational Codeforces Round 99 (Rated for Div. 2) D. Sequence and Swaps(貪心)
- Educational Codeforces Round 158 (Rated for Div. 2) - VP記錄
- Educational Codeforces Round 166 (Rated for Div. 2) - VP記錄
- Educational Codeforces Round 162 (Rated for Div. 2) - VP記錄
- Educational Codeforces Round 163 (Rated for Div. 2) - VP記錄
- Educational Codeforces Round 159 (Rated for Div. 2) - VP記錄
- 【CodeForces訓練記錄】Educational Codeforces Round 171 (Rated for Div. 2)
- Educational Codeforces Round 163 (Rated for Div. 2) 補題記錄(A~A)
- Educational Codeforces Round 95 (Rated for Div. 2) G. Three Occurrences
- [CF1954] Educational Codeforces Round 164 (Rated for Div. 2) 題解
- Educational Codeforces Round 165 (Rated for Div. 2) C. Minimizing the Sum題解
- Educational Codeforces Round 171 (Div. 2)
- Educational Codeforces Round 98 (Rated for Div. 2) E. Two Editorials 細節題
- Educational Codeforces Round 166 (Rated for Div. 2) (補題之抽象的自我審題)抽象
- Codeforces Round 941 (Div. 2) D
- Codeforces Round 960 (Div. 2)(A - D)
- CodeTON Round 9 (Div. 1 + Div. 2, Rated, Prizes!](A~D)
- Educational Codeforces Round 53 (Rated for Div. 2) D. Berland Fair 二分+樹狀陣列 O(n*logn*logn) 思路AI陣列
- Codeforces Round 720 (Div. 2) A-D