//Zadanie Szkola //Potyczki algorymiczne 2025 //Autor: AT #include <iostream> #include <algorithm> using namespace std; void wypisz(int tab[], int n) { for(int i = 0; i < n / 2; i++) { cout << "[" << tab[2*i] << " " << tab[2*i+1] << "] "; } cout << endl; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); long long int n, s; int m; cin >> n >> m >> s; int tab[2*m+7]; for(int i = 0; i < 2 * m; i++) { cin >> tab[i]; } //wypisz(tab, 2 * m); sort(tab, tab + 2 * m); //wypisz(tab, 2 * m); long long int MinDyst = n; long long int d = 0; if (tab[0] > 1) { MinDyst = s - tab[0] + 1; d = tab[0] - 1; } int k = 2; while(k < 2 * m and tab[k] < s) { if(tab[k] > tab[k-1]+1) { //MinDyst = min(MinDyst, s - tab[k] + 1); if(MinDyst > s - tab[k] + 1) { MinDyst = s - tab[k] + 1; d = tab[k] - 1; } } k = k + 2; } k--; while(k < 2 * m ) { if(tab[k] < tab[k-1] - 1) { //MinDyst = min(MinDyst, tab[k] - s + 1); if(MinDyst > tab[k] - s + 1) { MinDyst = tab[k] - s + 1; d = tab[k-1] + 1; } } k = k + 2; } if(tab[2 * m - 1] < n) { if(MinDyst > tab[2 * m - 1] - s + 1) { MinDyst = tab[2 * m - 1] - s + 1; d = tab[2 * m - 1] + 1; } } //cout << MinDyst << endl; //cout << "pozycja domu do wynajecia " << d << endl; cout << d << endl; } /* we: 10 2 7 5 9 1 2 wy: 4 we: 15 4 9 4 5 10 13 1 1 6 9 wy: 14 */
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 | //Zadanie Szkola //Potyczki algorymiczne 2025 //Autor: AT #include <iostream> #include <algorithm> using namespace std; void wypisz(int tab[], int n) { for(int i = 0; i < n / 2; i++) { cout << "[" << tab[2*i] << " " << tab[2*i+1] << "] "; } cout << endl; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); long long int n, s; int m; cin >> n >> m >> s; int tab[2*m+7]; for(int i = 0; i < 2 * m; i++) { cin >> tab[i]; } //wypisz(tab, 2 * m); sort(tab, tab + 2 * m); //wypisz(tab, 2 * m); long long int MinDyst = n; long long int d = 0; if (tab[0] > 1) { MinDyst = s - tab[0] + 1; d = tab[0] - 1; } int k = 2; while(k < 2 * m and tab[k] < s) { if(tab[k] > tab[k-1]+1) { //MinDyst = min(MinDyst, s - tab[k] + 1); if(MinDyst > s - tab[k] + 1) { MinDyst = s - tab[k] + 1; d = tab[k] - 1; } } k = k + 2; } k--; while(k < 2 * m ) { if(tab[k] < tab[k-1] - 1) { //MinDyst = min(MinDyst, tab[k] - s + 1); if(MinDyst > tab[k] - s + 1) { MinDyst = tab[k] - s + 1; d = tab[k-1] + 1; } } k = k + 2; } if(tab[2 * m - 1] < n) { if(MinDyst > tab[2 * m - 1] - s + 1) { MinDyst = tab[2 * m - 1] - s + 1; d = tab[2 * m - 1] + 1; } } //cout << MinDyst << endl; //cout << "pozycja domu do wynajecia " << d << endl; cout << d << endl; } /* we: 10 2 7 5 9 1 2 wy: 4 we: 15 4 9 4 5 10 13 1 1 6 9 wy: 14 */ |