#include #include using namespace std; using namespace atcoder; void fast_io() { ios_base::sync_with_stdio(false); cin.tie(nullptr); } int main() { fast_io(); int n; cin >> n; vector p(n); for (int i = 0; i < n; i++) { cin >> p[i]; p[i]--; } dsu uf(n); for (int i = 0; i < n; i++) { uf.merge(i, p[i]); } int ans = 0; for (auto g : uf.groups()) { ans += g.size() - 1; } cout << ans << endl; }