#include <bits/stdc++.h> using namespace std; int n, m, a, b, c, odp; int t[1001000][3]; int d[3]; int main() { scanf("%d%d", &n, &m); for(int i=1; i<=m; ++i) { scanf("%d%d%d", &a, &b, &c); ++t[a][--c]; --t[b+1][c]; } for(int i=1; i<=n; ++i) { d[0]+=t[i][0]; d[1]+=t[i][1]; d[2]+=t[i][2]; odp+=(d[0] && d[1] && !d[2]); } printf("%d\n", odp); return 0; }
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 | #include <bits/stdc++.h> using namespace std; int n, m, a, b, c, odp; int t[1001000][3]; int d[3]; int main() { scanf("%d%d", &n, &m); for(int i=1; i<=m; ++i) { scanf("%d%d%d", &a, &b, &c); ++t[a][--c]; --t[b+1][c]; } for(int i=1; i<=n; ++i) { d[0]+=t[i][0]; d[1]+=t[i][1]; d[2]+=t[i][2]; odp+=(d[0] && d[1] && !d[2]); } printf("%d\n", odp); return 0; } |