http://codeforces.com/contest/103/problem/D

As you know, the most intelligent beings on the Earth are, of course, cows. This conclusion was reached long ago by the Martian aliens, as well as a number of other intelligent civilizations from outer space.

Sometimes cows gather into cowavans. This seems to be seasonal. But at this time the cows become passive and react poorly to external stimuli. A cowavan is a perfect target for the Martian scientific saucer, it's time for large-scale abductions, or, as the Martians say, raids. Simply put, a cowavan is a set of cows in a row.

If we number all cows in the cowavan with positive integers from 1 to n, then we can formalize the popular model of abduction, known as the (a, b)-Cowavan Raid: first they steal a cow number a, then number a + b, then — number a + 2·b, and so on, until the number of an abducted cow exceeds n. During one raid the cows are not renumbered.

The aliens would be happy to place all the cows on board of their hospitable ship, but unfortunately, the amount of cargo space is very, very limited. The researchers, knowing the mass of each cow in the cowavan, made p scenarios of the (a, b)-raid. Now they want to identify the following thing for each scenario individually: what total mass of pure beef will get on board of the ship. All the scenarios are independent, in the process of performing the calculations the cows are not being stolen.

Input

The first line contains the only positive integer n (1 ≤ n ≤ 3·105) — the number of cows in the cowavan.

The second number contains n positive integer wi, separated by spaces, where the i-th number describes the mass of the i-th cow in the cowavan (1 ≤ wi ≤ 109).

The third line contains the only positive integer p — the number of scenarios of (a, b)-raids (1 ≤ p ≤ 3·105).

Each following line contains integer parameters a and b of the corresponding scenario (1 ≤ a, b ≤ n).

Output

Print for each scenario of the (a, b)-raid the total mass of cows, that can be stolen using only this scenario.

Please, do not use the %lld specificator to read or write 64-bit integers in С++. It is recommended to use the cin, cout streams of the %I64d specificator.

Examples

Input

3
1 2 3
2
1 1
1 2

Output

6
4

Input

4
2 3 5 7
3
1 3
2 3
2 2

Output

9
3
10

本题需要用到分块+离线处理。 

#include <iostream>
#include<string.h>
#include<algorithm>
#include<math.h>
#include <stdio.h>
using namespace std;
typedef long long  ll;
const int N=300000+100;
ll w[N],ans[N],sum[N];
int n,p,A,B,sq;
struct Query
{
    int id,a,b;
    bool operator <(const Query &s)const
    {
        return b<s.b;
    }

}q[300010];

int main()
{
    while(~scanf("%d",&n)){
        sq=sqrt(n);
        for(int i=1;i<=n;i++){
            //bl[i]=(i-1)/sq+1;
            scanf("%I64d",&w[i]);
        }
        scanf("%d",&p);
        for(int i=1;i<=p;i++){
            q[i].id=i;
            scanf("%d%d",&q[i].a,&q[i].b);

        }
        q[0].b=0;
        sort(q+1,q+p+1);
        for(int i=1;i<=p;i++){
            if(q[i].b<sq){
                if(q[i].b!=q[i-1].b){
                   for(int j=n;j>=1;j--){
                        if (j>n-q[i].b) 
                            sum[j]=w[j];
                        else 
                            sum[j]=sum[j+q[i].b]+w[j];
                    }
                }
                ans[q[i].id]=sum[q[i].a];

            }else{
                ans[q[i].id]=0;
                for(int j=q[i].a;j<=n;j+=q[i].b)
                    ans[q[i].id]+=w[j];

            }
        }
        for(int i=1;i<=p;i++){
            printf("%I64d\n",ans[i]);
        }
    }
    //cout << "Hello world!" << endl;
    return 0;
}