結果

問題 No.325 マンハッタン距離2
ユーザー sugim48sugim48
提出日時 2015-12-18 00:19:54
言語 C++11
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 1,815 bytes
コンパイル時間 599 ms
コンパイル使用メモリ 80,296 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-09-16 07:50:59
合計ジャッジ時間 1,506 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 AC 1 ms
5,376 KB
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 AC 2 ms
5,376 KB
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 AC 2 ms
5,376 KB
testcase_24 AC 1 ms
5,376 KB
testcase_25 WA -
testcase_26 WA -
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘ll solve(ll, ll, ll, ll, ll)’:
main.cpp:68:1: warning: control reaches end of non-void function [-Wreturn-type]
   68 | }
      | ^

ソースコード

diff #

#define _USE_MATH_DEFINES
#include <algorithm>
#include <cstdio>
#include <functional>
#include <iostream>
#include <cfloat>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <map>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <string>
#include <time.h>
#include <vector>
using namespace std;

typedef long long ll;
typedef unsigned long long ull;
typedef pair<int, int> i_i;
typedef pair<ll, int> ll_i;
typedef pair<double, int> d_i;
typedef pair<ll, ll> ll_ll;
typedef pair<double, double> d_d;
struct edge { int u, v; ll w; };

ll MOD = 1000000007;
ll _MOD = 1000000009;
double EPS = 1e-10;

int INF = INT_MAX / 2;

ll f(ll x, ll y, ll d) {
	if (x > y) swap(x, y);
	if (x < 0) return 0;
	if (d <= x) return d * (d + 1) / 2;
	else if (d <= y) return x * (x + 1) / 2 + (x - d) * (x + 1);
	else if (d < x + y) {
		ll _d = x + y - d - 1;
		return (x + 1) * (y + 1) - _d * (_d + 1) / 2;
	}
	return (x + 1) * (y + 1);
}

ll g(ll x1, ll y1, ll x2, ll y2, ll d) {
	return f(x2, y2, d) - f(x2, y1 - 1, d) - f(x1 - 1, x2, d) - f(x1 - 1, y1 - 1, d);
}

ll solve(ll x1, ll y1, ll x2, ll y2, ll d) {
	if (x1 < 0 && x2 < 0) {
		x1 *= -1; x2 *= -1;
		swap(x1, x2);
	}
	if (y1 < 0 && y2 < 0) {
		y1 *= -1; y2 *= -1;
		swap(y1, y2);
	}
	if (y1 < 0) {
		swap(x1, y1);
		swap(x2, y2);
	}
	if (x1 >= 0 && y1 >= 0) return g(x1, y1, x2, y2, d);
	if (x1 < 0 && y1 >= 0) return g(0, y1, -x1, y2, d) + g(0, y1, x2, y2, d) - g(0, y1, 0, y2, d);
	if (x1 < 0 && y1 < 0) return g(0, 0, -x1, -y1, d) + g(0, 0, -x1, y2, d) + g(0, 0, x2, -y1, d) + g(0, 0, x2, y2, d) - g(0, 0, -x1, 0, d) - g(0, 0, 0, -y1, d) - g(0, 0, x2, 0, d) - g(0, 0, 0, y2, d) + 1;
}

int main() {
	ll x1, y1, x2, y2; cin >> x1 >> y1 >> x2 >> y2;
	ll d; cin >> d;
	cout << solve(x1, y1, x2, y2, d) << endl;
}
0