#include <iostream> #include <string> #include <cctype> #include <random> #define SIZE_OF_ARRAY(x) (sizeof(x) / sizeof(*(x))) typedef unsigned int uint; static char get_char_buffer[4 * 1024]; static std::size_t get_char_buffer_i = SIZE_OF_ARRAY(get_char_buffer); static std::size_t get_char_buffer_n = SIZE_OF_ARRAY(get_char_buffer); static char get_char_prefix = 0; static char get_char_result = 0; int get_char() { get_char_result = 0; if (get_char_prefix) { get_char_result = get_char_prefix; get_char_prefix = 0; } else if (get_char_buffer_n == 0) { get_char_result = std::char_traits<char>::eof(); } else if (get_char_buffer_i < get_char_buffer_n) { get_char_result = get_char_buffer[get_char_buffer_i++]; } else { std::cin.read(get_char_buffer, SIZE_OF_ARRAY(get_char_buffer)); get_char_buffer_i = 0; get_char_buffer_n = std::cin.gcount(); return get_char(); } return get_char_result; } void unget_char() { get_char_prefix = get_char_result; } uint get_uint() { int c; while (isspace(c = get_char())); uint value = (c - '0'); while (isdigit(c = get_char())) { value = (10 * value) + (c - '0'); } return value; } int main() { std::ios_base::sync_with_stdio(false); std::cin.tie(0); uint result = 0; uint n = get_uint(); uint m = get_uint(); result += n + m; for (uint i = 0; i < n; ++i) { uint p = get_uint(); uint k = get_uint(); uint c = get_uint(); result += k - p + c; } std::mt19937 rng; rng.seed(result); std::uniform_int_distribution<std::mt19937::result_type> next_rand(0, 1); if (next_rand(rng) == 0) { std::cout << "NIE\n"; } else { std::cout << "TAK\n"; } 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 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 | #include <iostream> #include <string> #include <cctype> #include <random> #define SIZE_OF_ARRAY(x) (sizeof(x) / sizeof(*(x))) typedef unsigned int uint; static char get_char_buffer[4 * 1024]; static std::size_t get_char_buffer_i = SIZE_OF_ARRAY(get_char_buffer); static std::size_t get_char_buffer_n = SIZE_OF_ARRAY(get_char_buffer); static char get_char_prefix = 0; static char get_char_result = 0; int get_char() { get_char_result = 0; if (get_char_prefix) { get_char_result = get_char_prefix; get_char_prefix = 0; } else if (get_char_buffer_n == 0) { get_char_result = std::char_traits<char>::eof(); } else if (get_char_buffer_i < get_char_buffer_n) { get_char_result = get_char_buffer[get_char_buffer_i++]; } else { std::cin.read(get_char_buffer, SIZE_OF_ARRAY(get_char_buffer)); get_char_buffer_i = 0; get_char_buffer_n = std::cin.gcount(); return get_char(); } return get_char_result; } void unget_char() { get_char_prefix = get_char_result; } uint get_uint() { int c; while (isspace(c = get_char())); uint value = (c - '0'); while (isdigit(c = get_char())) { value = (10 * value) + (c - '0'); } return value; } int main() { std::ios_base::sync_with_stdio(false); std::cin.tie(0); uint result = 0; uint n = get_uint(); uint m = get_uint(); result += n + m; for (uint i = 0; i < n; ++i) { uint p = get_uint(); uint k = get_uint(); uint c = get_uint(); result += k - p + c; } std::mt19937 rng; rng.seed(result); std::uniform_int_distribution<std::mt19937::result_type> next_rand(0, 1); if (next_rand(rng) == 0) { std::cout << "NIE\n"; } else { std::cout << "TAK\n"; } return 0; } |