#include <algorithm>
#include <cstdio>
using namespace std;
const int N = 505, M = N * N;
int n, i, x, j, a[M];
struct arr {
  int x, k;
} d[N];
bool operator<(arr A, arr B) { return A.x < B.x; }
void write(int x) {
  if (x > 9)
    write(x / 10);
  putchar(x % 10 + 48);
}
int main() {
  for (scanf("%d", &n), i = 1; i <= n; i++)
    scanf("%d", &d[i].x), d[i].k = i;
  sort(d + 1, d + n + 1);
  x = 1;
  for (i = 1; i <= n; i++) {
    int k = d[i].k, nx = d[i].x;
    for (j = k - 1; j && x < nx; j--) {
      for (; a[x]; x++)
        ;
      a[x] = k;
    }
    if (a[nx]) {
      puts("No");
      return 0;
    }
    a[nx] = k;
  }
  for (x = n * n, i = n; i; i--) {
    int k = d[i].k, nx = d[i].x;
    for (j = n - k; j && x >= nx; j--) {
      for (; a[x]; x--)
        ;
      a[x] = k;
    }
    if (x < nx) {
      puts("No");
      return 0;
    }
  }
  puts("Yes");
  for (i = 1; i <= n * n; i++)
    write(a[i]), putchar(' ');
}