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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#include <iostream>
using namespace std;

const int base=1<<20;

int tab[2*base+10][4];
int n, m;
int a, b, k;

int main()
{
    cin.tie(0);
    cout.tie(0);
    ios_base::sync_with_stdio(0);
    //cout << base;
    cin >> n >> m;
    while(m>0)
    {
        cin >> a >> b >> k;
        a=a-1+base;
        b=b-1+base;
        while(a<=b)
        {
            if(a%2==0)
                a=a/2;
            else
            {
                tab[a][k]=1;
                a=a/2+1;
            }
            if(b%2==1)
                b=b/2;
            else
            {
                tab[b][k]=1;
                b=b/2-1;
            }
        }
        if(a==b)
            tab[a][k]=1;
        m--;
    }
    int wynik=0;
    for(int i=base; i<=base*2; i++)
    {
        bool czy_niebieski=false;
        bool czy_zolty=false;
        bool czy_czerwony=false;
        int l=i;
        while(l>0)
        {
            if(tab[l][1]==1)
            {
                czy_zolty=true;
                break;
            }
            l=l/2;
        }
        if(tab[0][1]==1)
            czy_zolty=true;
        l=i;
        while(l>0)
        {
            if(tab[l][2]==1)
            {
                czy_niebieski=true;
                break;
            }
            l=l/2;
        }
        if(tab[0][2]==1)
            czy_niebieski=true;
        l=i;
        while(l>0)
        {
            if(tab[l][3]==1)
            {
                czy_czerwony=true;
                break;
            }
            l=l/2;
        }
        if(tab[0][3]==1)
            czy_czerwony=true;
    if(czy_zolty && czy_niebieski && !czy_czerwony)
        wynik++;
    }
    cout << wynik;
    return 0;
}