n = int(input()) p = [int(x) % n for x in input().split()] assert 1 <= n <= 2 * 10 ** 5 sp = sorted(p) for i in range(n): assert sp[i] == i use = [0] * n cycle = [[] for i in range(n+1)] for i in range(n): if use[i]: continue u = p[i] c = [u] use[u] = 1 while i != u: u = p[u] c.append(u) use[u] = 1 cycle[len(c)].append(c) r = [-1] * n for l in range(1, n+1): if l % 2 == 0: if len(cycle[l]) % 2 == 1: print("No") exit() while cycle[l]: a = cycle[l].pop() b = cycle[l].pop() c = [0] * (l * 2) c[0::2] = a c[1::2] = b for i in range(2 * l): r[c[i]] = c[(i+1)%(2*l)] else: h = (l+1) // 2 while cycle[l]: c = cycle[l].pop() for i in range(l): r[c[i]] = c[(h+i)%l] print("Yes") r = [n if x == 0 else x for x in r] print(*r)