# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
89015 | Lkvatashidze | Experiments with Gorlum (IZhO13_expgorl) | C++17 | 228 ms | 696 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define ll long long
using namespace std;
double mn, mx;
int k;
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin >> k;
string s;
cin >> s;
double x, y, x1, y1;
cin >> x >> y;
cin >> x1 >> y1;
mn=sqrt((x1-x)*(x1-x)+(y-y1)*(y-y1));
int n=s.size();
if (n*k<80000000) {
while (k--)
for (int i=0; i<n; i++) {
if (s[i]=='L')
x1--;
if (s[i]=='R')
x1++;
if (s[i]=='F')
y1++;
if (s[i]=='B')
y1--;
double p=sqrt((x1-x)*(x1-x)+(y-y1)*(y-y1));
mn=min(mn,p);
mx=max(mx,p);
}
cout << fixed << setprecision(12) << mn << ' ';
cout << fixed << setprecision(12) << mx;
}
else {
int x2=0, y2=0;
for (int i=0; i<n; i++) {
if (s[i]=='L')
x1--, x2--;
if (s[i]=='R')
x1++, x2++;
if (s[i]=='F')
y1++, y2++;
if (s[i]=='B')
y1--, y2--;
double p=sqrt((x1-x)*(x1-x)+(y-y1)*(y-y1));
mn=min(mn,p);
mx=max(mx,p);
}
k--;
while (k>0) {
x1+=x2;
y1+=y2;
k--;
double p=sqrt((x1-x)*(x1-x)+(y-y1)*(y-y1));
mn=min(mn,p);
mx=max(mx,p);
}
cout << fixed << setprecision(12) << mn << ' ';
cout << fixed << setprecision(12) << mx;
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |