結果
| 問題 |
No.859 路線A、路線B、路線C
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2019-08-10 10:33:20 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 1,000 ms |
| コード長 | 2,224 bytes |
| コンパイル時間 | 575 ms |
| コンパイル使用メモリ | 64,764 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-19 17:00:28 |
| 合計ジャッジ時間 | 1,223 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 12 |
ソースコード
#include <iostream>
using namespace std;
typedef long long LL;
LL x,y,z;
LL GetAB(LL A,LL B)
{
LL D1=A-1+1+B-1;
if (D1<0){
D1=-D1;
}
LL D2=x-A+1+y-B;
if (D2<0){
D2=-D2;
}
LL D3=A-1+1+z-1+1+y-B;
if (D3<0){
D3=-D3;
}
LL D4=x-A+1+z-1+1+B-1;
if (D4<0){
D4=-D4;
}
return min(D1,min(D2,min(D3,D4)));
}
LL GetAC(LL A,LL C)
{
LL D1=A-1+1+C-1;
if (D1<0){
D1=-D1;
}
LL D2=x-A+1+z-C;
if (D2<0){
D2=-D2;
}
LL D3=A-1+1+y-1+1+z-C;
if (D3<0){
D3=-D3;
}
LL D4=x-A+1+y-1+1+C-1;
if (D4<0){
D4=-D4;
}
return min(D1,min(D2,min(D3,D4)));
}
LL GetBC(LL B,LL C)
{
LL D1=B-1+1+C-1;
if (D1<0){
D1=-D1;
}
LL D2=y-B+1+z-C;
if (D2<0){
D2=-D2;
}
LL D3=B-1+1+x-1+1+z-C;
if (D3<0){
D3=-D3;
}
LL D4=y-B+1+x-1+1+C-1;
if (D4<0){
D4=-D4;
}
return min(D1,min(D2,min(D3,D4)));
}
LL GetAA(LL Ai,LL Aj)
{
if (Ai>Aj){
swap(Ai,Aj);
}
LL D1=Ai-Aj;
if (D1<0){
D1=-D1;
}
LL D2=Ai-1+1+y-1+1+x-Aj;
if (D2<0){
D2=-D2;
}
LL D3=Ai-1+1+z-1+1+x-Aj;
if (D3<0){
D3=-D3;
}
return min(D1,min(D2,D3));
}
LL GetBB(LL Bi,LL Bj)
{
if (Bi>Bj){
swap(Bi,Bj);
}
LL D1=Bi-Bj;
if (D1<0){
D1=-D1;
}
LL D2=Bi-1+1+x-1+1+y-Bj;
if (D2<0){
D2=-D2;
}
LL D3=Bi-1+1+z-1+1+y-Bj;
if (D3<0){
D3=-D3;
}
return min(D1,min(D2,D3));
}
LL GetCC(LL Ci,LL Cj)
{
if (Ci>Cj){
swap(Ci,Cj);
}
LL D1=Ci-Cj;
if (D1<0){
D1=-D1;
}
LL D2=Ci-1+1+x-1+1+z-Cj;
if (D2<0){
D2=-D2;
}
LL D3=Ci-1+1+y-1+1+z-Cj;
if (D3<0){
D3=-D3;
}
return min(D1,min(D2,D3));
}
int main(int argc, char* argv[])
{
char S0,S1;
LL t0,t1;
cin>>x>>y>>z;
cin>>S0>>t0;
cin>>S1>>t1;
if (S0=='A' && S1=='A'){
cout<<GetAA(t0,t1)<<endl;
return 0;
}
if (S0=='B' && S1=='B'){
cout<<GetBB(t0,t1)<<endl;
return 0;
}
if (S0=='C' && S1=='C'){
cout<<GetCC(t0,t1)<<endl;
return 0;
}
if (S0=='A' && S1=='B'){
cout<<GetAB(t0,t1)<<endl;
return 0;
}
if (S0=='B' && S1=='A'){
cout<<GetAB(t1,t0)<<endl;
return 0;
}
if (S0=='A' && S1=='C'){
cout<<GetAC(t0,t1)<<endl;
return 0;
}
if (S0=='C' && S1=='A'){
cout<<GetAC(t1,t0)<<endl;
return 0;
}
if (S0=='B' && S1=='C'){
cout<<GetBC(t0,t1)<<endl;
return 0;
}
if (S0=='C' && S1=='B'){
cout<<GetBC(t1,t0)<<endl;
return 0;
}
return 0;
}