#include <iostream>
#include <string>
#include <sstream>
using namespace std;
bool Check(int* tab, int value, int size)
{
for (int j = 0; j < size; j = j + 2) {
if (tab[j] <= value && tab[j + 1] >= value)
return true;
}
return false;
}
int main()
{
string str;
string nm;
int n;
int m;
//first row
getline(cin >> ws, nm);
istringstream f(nm);
getline(f, str, ' ');
n = std::stoi(str);
getline(f, str, ' ');
m = std::stoi(str);
int* yellow;
yellow = (int*)malloc(2*m * sizeof(int));
int size_yellow = 0;
int* blue;
blue = (int*)malloc(2 * m * sizeof(int));
int size_blue = 0;
int* red;
red = (int*)malloc(2 * m * sizeof(int));
int size_red = 0;
for(int j = 0; j < m; j++)
{
string lcr;
getline(cin >> ws, lcr);
int l;
int r;
int c;
istringstream f(lcr);
getline(f, str, ' ');
l = std::stoi(str);
getline(f, str, ' ');
r = std::stoi(str);
getline(f, str, ' ');
c = std::stoi(str);
if (c == 1)
{
yellow[size_yellow] = l;
yellow[size_yellow+1] = r;
size_yellow = size_yellow + 2;
}
else if (c == 2)
{
blue[size_blue] = l;
blue[size_blue+1] = r;
size_blue = size_blue + 2;
}
else
{
red[size_red] = l;
red[size_red+1] = r;
size_red = size_red + 2;
}
}
int count = 0;
for (int i = 1; i <= n; i++)
{
bool green = false;
if (size_yellow < size_blue && size_yellow < size_red)
{
green = Check(yellow, i, size_yellow);
if (green && size_blue < size_red)
{
green &= Check(blue, i, size_blue) && !Check(red, i, size_red);
}
else if (green)
{
green &= !Check(red, i, size_red) && Check(blue, i, size_blue);
}
}
else if (size_blue < size_yellow && size_blue < size_red)
{
green = Check(blue, i, size_blue);
if (green && size_yellow < size_red)
{
green &= Check(yellow, i, size_yellow) && !Check(red, i, size_red);
}
else if (green)
{
green &= !Check(red, i, size_red) && Check(yellow, i, size_yellow);
}
}
else
{
green = !Check(red, i, size_red);
if (green && size_yellow < size_blue)
{
green &= Check(yellow, i, size_yellow) && Check(blue, i, size_blue);
}
else if (green)
{
green &= Check(blue, i, size_blue) && Check(yellow, i, size_yellow);
}
}
if (green)
count++;
}
cout << count;
}
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 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 | #include <iostream> #include <string> #include <sstream> using namespace std; bool Check(int* tab, int value, int size) { for (int j = 0; j < size; j = j + 2) { if (tab[j] <= value && tab[j + 1] >= value) return true; } return false; } int main() { string str; string nm; int n; int m; //first row getline(cin >> ws, nm); istringstream f(nm); getline(f, str, ' '); n = std::stoi(str); getline(f, str, ' '); m = std::stoi(str); int* yellow; yellow = (int*)malloc(2*m * sizeof(int)); int size_yellow = 0; int* blue; blue = (int*)malloc(2 * m * sizeof(int)); int size_blue = 0; int* red; red = (int*)malloc(2 * m * sizeof(int)); int size_red = 0; for(int j = 0; j < m; j++) { string lcr; getline(cin >> ws, lcr); int l; int r; int c; istringstream f(lcr); getline(f, str, ' '); l = std::stoi(str); getline(f, str, ' '); r = std::stoi(str); getline(f, str, ' '); c = std::stoi(str); if (c == 1) { yellow[size_yellow] = l; yellow[size_yellow+1] = r; size_yellow = size_yellow + 2; } else if (c == 2) { blue[size_blue] = l; blue[size_blue+1] = r; size_blue = size_blue + 2; } else { red[size_red] = l; red[size_red+1] = r; size_red = size_red + 2; } } int count = 0; for (int i = 1; i <= n; i++) { bool green = false; if (size_yellow < size_blue && size_yellow < size_red) { green = Check(yellow, i, size_yellow); if (green && size_blue < size_red) { green &= Check(blue, i, size_blue) && !Check(red, i, size_red); } else if (green) { green &= !Check(red, i, size_red) && Check(blue, i, size_blue); } } else if (size_blue < size_yellow && size_blue < size_red) { green = Check(blue, i, size_blue); if (green && size_yellow < size_red) { green &= Check(yellow, i, size_yellow) && !Check(red, i, size_red); } else if (green) { green &= !Check(red, i, size_red) && Check(yellow, i, size_yellow); } } else { green = !Check(red, i, size_red); if (green && size_yellow < size_blue) { green &= Check(yellow, i, size_yellow) && Check(blue, i, size_blue); } else if (green) { green &= Check(blue, i, size_blue) && Check(yellow, i, size_yellow); } } if (green) count++; } cout << count; } |
English