100 atcoder#ABC184C. [ABC184C] Super Ryuma

[ABC184C] Super Ryuma

配点 : 300300

問題文

無限に広がる 22 次元グリッドがあり、マス (r1,c1)(r_1, c_1) に駒「超竜馬」が置かれています。 この駒は、 11 手で次のような動きができます。

より正確には、超竜馬がマス (a,b)(a, b) にあるとき、以下のいずれかの条件を満たすマス (c,d)(c, d) に動かすことができます。

  • a+b=c+da + b = c + d
  • ab=cda - b = c - d
  • ac+bd3|a - c| + |b - d| \le 3

超竜馬を (r1,c1)(r_1, c_1) から (r2,c2)(r_2, c_2) に動かすのに必要な最小手数を求めてください。

制約

  • 入力は全て整数
  • 1r1,c1,r2,c21091 \le r_1, c_1, r_2, c_2 \le 10^9

入力

入力は以下の形式で標準入力から与えられる。

r1r_1 c1c_1

r2r_2 c2c_2

出力

超竜馬を (r1,c1)(r_1, c_1) から (r2,c2)(r_2, c_2) に動かすのに必要な最小手数を出力せよ。

1 1
5 6
2

例えば、 (1,1)(5,5)(5,6)(1, 1) \rightarrow (5, 5) \rightarrow (5, 6) と動かすと 22 手になります。

1 1
1 200001
2

例えば、 $(1, 1) \rightarrow (100001, 100001) \rightarrow (1, 200001)$ と動かすと 22 手になります。

2 3
998244353 998244853
3

例えば、 $(2, 3) \rightarrow (3, 3) \rightarrow (-247, 253) \rightarrow (998244353, 998244853)$ と動かすと 33 手になります。

1 1
1 1
0