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
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
#include <iostream>
#include <algorithm>
#include <vector>
#include <cstdio>
using namespace std;

vector<pair<int,int> > zolty;
vector<pair<int,int> > niebieski;
vector<pair<int,int> > czerwony;
int kolor[1000003];
int main() 
{
	int N,M,l,r,k;
	scanf("%d%d", &N,&M);
	for (int i=0; i<M; i++)
	{
		scanf("%d%d%d", &l,&r,&k);
		if (k==1)
			zolty.push_back(make_pair(l,r));
		if (k==2)
			niebieski.push_back(make_pair(l,r));
		if (k==3)
			czerwony.push_back(make_pair(l,r));
			
	}
	sort(zolty.begin(), zolty.end());
	sort(niebieski.begin(), niebieski.end());
	sort(czerwony.begin(), czerwony.end());
	
	int s=0,e=0;
	for (int i=0; i<zolty.size(); i++)
	{
		if (zolty[i].first>e)
		{
			for (int j=zolty[i].first; j<=zolty[i].second; j++)
				kolor[j]=1;
			s=zolty[i].first;
			e=zolty[i].second;
			continue;
		}
		else
		{
			for (int j=e; j<=zolty[i].second; j++)
				kolor[j]=1;
			s=zolty[i].first;
			e=zolty[i].second;
		}
	}
	
	
	
	s=0,e=0;
	for (int i=0; i<niebieski.size(); i++)
	{
		if (niebieski[i].first>e)
		{
			for (int j=niebieski[i].first; j<=niebieski[i].second; j++)
				if (kolor[j]==1)
					kolor[j]=2;
			s=niebieski[i].first;
			e=niebieski[i].second;
			continue;
		}
		else
		{
			for (int j=e; j<=niebieski[i].second; j++)
				if (kolor[j]==1)
					kolor[j]=2;
			s=niebieski[i].first;
			e=niebieski[i].second;
		}
	}
	
	s=0,e=0;
	for (int i=0; i<czerwony.size(); i++)
	{
		if (czerwony[i].first>e)
		{
			for (int j=czerwony[i].first; j<=czerwony[i].second; j++)
				if (kolor[j]==2)
					kolor[j]=3;
			s=czerwony[i].first;
			e=czerwony[i].second;
			continue;
		}
		else
		{
			for (int j=e; j<=czerwony[i].second; j++)
				if (kolor[j]==2)
					kolor[j]=3;
			s=czerwony[i].first;
			e=czerwony[i].second;
		}
	}
	
	int ile=0;
	for (int i=1; i<=N; i++)
	{
		if (kolor[i]==2)
			ile++;
	}
	printf("%d\n", ile);
	return 0;
}