显示原始代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 1e5 + 10, mod = 1e9 + 7;
int a[N], sum[N], fac;
inline int read() {
int x = 0, f = 1;
char c = getchar();
while (c < '0' || c > '9') {
if (c == '-')
f = -1;
c = getchar();
}
while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
signed main() {
int n = read();
sum[0] = 0, fac = 1;
for (int i = 1; i <= n; i++) a[i] = read(), sum[i] = sum[i - 1] + a[i];
for (int i = 1; i <= n; i++) fac = fac * a[i] % mod;
a[1] = 1;
for (int i = 1; i <= n; i++) {
int aa = sum[i - 1] - (sum[n] - sum[i]);
fac /= a[i];
printf("%lld %lld\n", aa, fac % mod);
fac *= a[i];
}
return 0;
}