#include<bits/stdc++.h> using namespace std; int tab[4][1000006]; int n, m, a, b, c, w; int main() { scanf("%d%d", &n, &m); for(int i=0; i<m; ++i) { scanf("%d%d%d", &a, &b, &c); tab[c][a]++; tab[c][b+1]--; } for(int i=1; i<=n; ++i) { tab[1][i]+=tab[1][i-1]; tab[2][i]+=tab[2][i-1]; tab[3][i]+=tab[3][i-1]; if(tab[1][i]>0 && tab[2][i]>0 && tab[3][i]==0) { w++; } } printf("%d", w); }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | #include<bits/stdc++.h> using namespace std; int tab[4][1000006]; int n, m, a, b, c, w; int main() { scanf("%d%d", &n, &m); for(int i=0; i<m; ++i) { scanf("%d%d%d", &a, &b, &c); tab[c][a]++; tab[c][b+1]--; } for(int i=1; i<=n; ++i) { tab[1][i]+=tab[1][i-1]; tab[2][i]+=tab[2][i-1]; tab[3][i]+=tab[3][i-1]; if(tab[1][i]>0 && tab[2][i]>0 && tab[3][i]==0) { w++; } } printf("%d", w); } |