#include <bits/stdc++.h>
using namespace std;
void solve()
{
    int n, m;
    cin >> n;
    vector<int> v(n);
    for (int i = 0; i < n; i++)
    {
        cin >> v[i];
    }
    vector<int>jump(n, 0), end_pos(n, 0), to(n, 0);
    for (int i = n - 1; i >= 0; i--) {
        int next = i + v[i];
        if(next >= n)
        {
            jump[i] = 1;
            end_pos[i] = i;
            to[i] = i + v[i];
        }
        else{
            jump[i] = 1 + jump[next];
            to[i] = to[next];
            end_pos[i] = end_pos[next];
        }
    }
    for(int i = 0; i < n; i++)
    {
        cout << end_pos[i] + 1 << " " << jump[i] << endl;
    }
}
int32_t main()
{
    ios::sync_with_stdio(false);cin.tie(0),cin.tie(0);
    int t = 1;
    // cin >> t;
    for (int tc = 1; tc <= t; ++tc)
    {
        // cout << "Case " << tc << ": ";
        solve();
    }
}