#include<bits/stdc++.h>
using namespace std;
const int N = 1010;
int a[N];
int st[N];
vector<int>g[N];
int n;
void dfs(int root){
for(auto x:g[root]){
st[x]=1;
dfs(x);
}
}
int main()
{
cin>>n;
int root=-1;
for(int i=1;i<=n;i++){
int a;
cin>>a;
g[a].push_back(i);
if(a==0) root=a;
}
dfs(root);
int res=0;
for(int i=1;i<=n;i++) if(st[i])res++;
cout<<res;
return 0;
}