#include #define rep(i, n) for (ll i = 0; i < (n); ++i) #define rep1(i, n) for (ll i = 1; i <= (n); ++i) #define rrep(i, n) for (ll i = (n - 1); i >= 0; --i) #define ALL(obj) (obj).begin(), (obj).end() #define pb push_back #define to_s to_string #define len(v) (ll)v.size() #define UNIQUE(v) v.erase(unique(v.begin(), v.end()), v.end()) #define print(x) cout << (x) << '\n' #define debug(x) cout << #x << ": " << (x) << '\n' using namespace std; using ll = long long; typedef pair P; ll MOD = 1e9 + 7; ll devc(ll x, ll y) { return 1 + (x - 1) / y; } int main() { cin.tie(0); ios::sync_with_stdio(0); cout << fixed << setprecision(20); ll N, K; cin >> N >> K; vector P(N + 5); rep1(i, N) cin >> P[i]; rep1(i,N){ ll now = i; ll ans = 0; rep(j, K){ now += P[now % N == 0 ? N : now % N]; if(P[now % N == 0 ? N : now % N] == N){ ans = now + (K-j-1)*N; break; } } if(ans == 0) print(now); else print(ans); } return 0; }