#include #include #include using namespace std; pair a[1004]; int d,n,m,i,p,u,nr,Max,b[1004]; int main() { scanf ("%d %d %d", &d, &n, &m); for (i=1;i<=n;i++) scanf ("%d", &b[i]); for (i=1;i<=m;i++) scanf ("%d %d", &a[i].first, &a[i].second); sort (a+1,a+n+1); p=1; u=1; nr=0; Max=0; while (p<=n) { while (u<=m) { if (a[u].first>b[p]) break; else if (a[u].second>Max) Max=a[u].second; u++; } while (p<=n) { if (b[p]>Max) break; p++; } nr++; } printf ("%d\n", nr); return 0; }