#pragma GCC optimize("Ofast") #pragma GCC optimize("unroll-loops") #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx") #include using namespace std; using ll = long long; using ui128 = __uint128_t; constexpr int MOD = (int)1e9 + 7; constexpr int MX = 100000; constexpr int MX_K = 200; int K, N, M, L, R; int A[MX + 1], C[MX_K + 1]; ll res[MX + 1]; ui128 tmp; int main() { scanf("%d%d%d", &K, &N, &M); for (int i = 0; i < K; ++i) scanf("%d", A + i); for (int i = 0; i < K; ++i) scanf("%d", C + i); for (int i = K; i < N; ++i) { tmp = 0; for (int j = 0; j < K; ++j) tmp += ll(C[j]) * A[i - 1 - j]; A[i] = tmp % MOD; } for (int i = 0; i < M; ++i) { scanf("%d%d", &L, &R); for (int j = L; j < R; ++j) res[j] += A[j - L]; } for (int i = 0; i < N; ++i) printf("%d\n", res[i] % MOD); }