// Source: https://usaco.guide/general/io
#include <asm-generic/errno.h>
#include <bits/stdc++.h>
using namespace std;
const int NMAX = 30000;
int aint[4 * NMAX + 1], v[NMAX + 1], a[NMAX + 1];
int sol;
void build(int node, int st, int dr) {
if(st == dr) {
aint[node] = 1;
} else {
int mid = (st + dr) / 2;
build(2 * node, st, mid);
build(2 * node + 1, mid + 1, dr);
aint[node] = aint[2 * node] + aint[2 * node + 1];
}
}
void update(int node, int st, int dr, int pos) {
if(st == dr) {
aint[node] = 0;
} else {
int mid = (st + dr) / 2;
if(pos <= mid) {
update(2 * node, st, mid, pos);
} else {
update(2 * node + 1, mid + 1, dr, pos);
}
aint[node] = aint[2 * node] + aint[2 * node + 1];
}
}
void query(int node, int st, int dr, int x, int y) {
if(x <= st && dr <= y) {
sol = sol + aint[node];
} else {
int mid = (st + dr) / 2;
//[x, y]
//[st, mid], [mid + 1, dr]
if(x <= mid) {
query(2 * node, st, mid, x, y);
}
if(mid + 1 <= y) {
query(2 * node + 1, mid + 1, dr, x, y);
}
}
}
int query_cb(int node, int st, int dr, int s) {
if(st == dr) {
return st;
} else {
int mid = (st + dr) / 2;
if(aint[2 * node] >= s) {
return query_cb(2 * node, st, mid, s);
} else {
return query_cb(2 * node + 1, mid + 1, dr, s - aint[2 * node]);
}
}
}
int main() {
ifstream cin("schi.in");
ofstream cout("schi.out");
int n;
cin >> n;
for(int i = 1; i <= n; i++) {
cin >> v[i];
}
build(1, 1, n);
for(int i = n; i >= 1; i--) {
//gasim prefixul de suma v[i]
int pos = query_cb(1, 1, n, v[i]);
a[pos] = i;
update(1, 1, n, pos);
}
for(int i = 1; i <= n; i++) {
cout << a[i] << '\n';
}
}