#include <bits/stdc++.h>
#include "cielib.h"
using namespace std;
#ifndef _WIN32
#define getchar getchar_unlocked
#endif
#define MP make_pair
#define PB push_back
#define ST first
#define ND second
typedef long long int LLI;
typedef unsigned long long int LLU;
typedef long double LD;
typedef pair<int, int> pii;
typedef pair<long long int, long long int> pll;
typedef vector<int> vi;
int n;
bool done[507];
int poczatek[507];
int koniec[507];
int aktualne[507];
void binsearch(int roz)
{
for(int i = 0; i < n; ++i)
aktualne[i] = (poczatek[i] + koniec[i]) / 2;
if(roz == 3)
{
for(int i = 0; i < n; ++i){
if(done[i] == 0){
aktualne[i] = poczatek[i];
czyCieplo(aktualne);
aktualne[i] = koniec[i];
if(czyCieplo(aktualne) == 1){
poczatek[i] = koniec[i];
aktualne[i] = koniec[i];
}
else{
aktualne[i] = poczatek[i];
if(czyCieplo(aktualne) == 1){
koniec[i] = poczatek[i];
aktualne[i] = poczatek[i];
}
else{
poczatek[i] = (poczatek[i] + koniec[i]) / 2;
koniec[i] = poczatek[i];
aktualne[i] = poczatek[i];
}
}
done[i] = 1;
}
}
}
else if(roz % 2 == 1)
{
for(int i = 0; i < n; ++i){
if(done[i] == 0){
int poprz = aktualne[i];
aktualne[i] = poczatek[i];
czyCieplo(aktualne);
aktualne[i] = koniec[i];
if(czyCieplo(aktualne) == 1)
poczatek[i] = (poczatek[i] + koniec[i]) / 2;
else{
aktualne[i] = poczatek[i];
if(czyCieplo(aktualne) == 1)
koniec[i] = (poczatek[i] + koniec[i]) / 2;
else{
poczatek[i] = (poczatek[i] + koniec[i]) / 2;
koniec[i] = poczatek[i];
aktualne[i] = poczatek[i];
done[i] = 1;
}
}
aktualne[i] = poprz;
}
}
binsearch(roz / 2 + 1);
}
else
{
for(int i = 0; i < n; ++i){
if(done[i] == 0){
int poprz = aktualne[i];
aktualne[i] = poczatek[i];
czyCieplo(aktualne);
aktualne[i] = koniec[i];
if(czyCieplo(aktualne) == 1)
poczatek[i] = (poczatek[i] + koniec[i]) / 2;
else
koniec[i] = ((poczatek[i] + koniec[i]) / 2) + 1;
aktualne[i] = poprz;
}
}
binsearch(roz / 2 + 1);
}
}
int main()
{
n = podajD();
int m = podajR();
for(int i = 0; i < n; ++i)
poczatek[i] = 0,
koniec[i] = m;
binsearch(m + 1);
int* wyn = new int[n];
for(int i = 0; i < n; ++i)
wyn[i] = poczatek[i];
znalazlem(wyn);
}
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 | #include <bits/stdc++.h> #include "cielib.h" using namespace std; #ifndef _WIN32 #define getchar getchar_unlocked #endif #define MP make_pair #define PB push_back #define ST first #define ND second typedef long long int LLI; typedef unsigned long long int LLU; typedef long double LD; typedef pair<int, int> pii; typedef pair<long long int, long long int> pll; typedef vector<int> vi; int n; bool done[507]; int poczatek[507]; int koniec[507]; int aktualne[507]; void binsearch(int roz) { for(int i = 0; i < n; ++i) aktualne[i] = (poczatek[i] + koniec[i]) / 2; if(roz == 3) { for(int i = 0; i < n; ++i){ if(done[i] == 0){ aktualne[i] = poczatek[i]; czyCieplo(aktualne); aktualne[i] = koniec[i]; if(czyCieplo(aktualne) == 1){ poczatek[i] = koniec[i]; aktualne[i] = koniec[i]; } else{ aktualne[i] = poczatek[i]; if(czyCieplo(aktualne) == 1){ koniec[i] = poczatek[i]; aktualne[i] = poczatek[i]; } else{ poczatek[i] = (poczatek[i] + koniec[i]) / 2; koniec[i] = poczatek[i]; aktualne[i] = poczatek[i]; } } done[i] = 1; } } } else if(roz % 2 == 1) { for(int i = 0; i < n; ++i){ if(done[i] == 0){ int poprz = aktualne[i]; aktualne[i] = poczatek[i]; czyCieplo(aktualne); aktualne[i] = koniec[i]; if(czyCieplo(aktualne) == 1) poczatek[i] = (poczatek[i] + koniec[i]) / 2; else{ aktualne[i] = poczatek[i]; if(czyCieplo(aktualne) == 1) koniec[i] = (poczatek[i] + koniec[i]) / 2; else{ poczatek[i] = (poczatek[i] + koniec[i]) / 2; koniec[i] = poczatek[i]; aktualne[i] = poczatek[i]; done[i] = 1; } } aktualne[i] = poprz; } } binsearch(roz / 2 + 1); } else { for(int i = 0; i < n; ++i){ if(done[i] == 0){ int poprz = aktualne[i]; aktualne[i] = poczatek[i]; czyCieplo(aktualne); aktualne[i] = koniec[i]; if(czyCieplo(aktualne) == 1) poczatek[i] = (poczatek[i] + koniec[i]) / 2; else koniec[i] = ((poczatek[i] + koniec[i]) / 2) + 1; aktualne[i] = poprz; } } binsearch(roz / 2 + 1); } } int main() { n = podajD(); int m = podajR(); for(int i = 0; i < n; ++i) poczatek[i] = 0, koniec[i] = m; binsearch(m + 1); int* wyn = new int[n]; for(int i = 0; i < n; ++i) wyn[i] = poczatek[i]; znalazlem(wyn); } |
English