結果

問題 No.48 ロボットの操縦
ユーザー kota
提出日時 2018-03-19 15:56:15
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 1,255 bytes
コンパイル時間 661 ms
コンパイル使用メモリ 55,340 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2024-12-31 10:45:29
合計ジャッジ時間 1,663 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 25
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
using namespace std;

int main()
{
	int X, Y, L, x, y;

	cin >> X >> Y >> L;

	//第一象限
	if (X >= 0 && Y >= 0)
	{
		if (X%L == 0)
		{
			x = X / L;
		}
		else
		{
			x = X / L + 1;
		}

		if (Y%L == 0)
		{
			y = Y / L;
		}
		else
		{
			y = Y / L + 1;
		}

		if (X == 0)
		{
			cout << y << endl;
		}
		else if (Y == 0)
		{
			cout << x << endl;
		}
		else
		{
			cout << y + 1 + x << endl;
		}

	}

	//第二象限
	else if (X < 0 && Y >= 0)
	{
		if (X%L == 0)
		{
			x = -1 * X / L;
		}
		else
		{
			x = -1 * X / L + 1;
		}

		if (Y%L == 0)
		{
			y = Y / L;
		}
		else 
		{
			y = Y / L + 1;
		}

		if (Y == 0)
		{
			cout << 1 + x << endl;
		}
		else
		{
			cout << y + 1 + x << endl;
		}

	}

	//第三象限
	else if (X <= 0 && Y < 0)
	{
		if (X%L == 0)
		{
			x = -1 * X / L;
		}
		else
		{
			x = -1 * X / L + 1;
		}

		if (Y%L == 0)
		{
			y = -1 * Y / L;
		}
		else
		{
			y = -1 * Y / L + 1;
		}

		if (X == 0)
		{
			cout << 2 + y << endl;
		}
		else
		{
			cout << 1 + x + 1 + y << endl;
		}		
	}

	//第四象限
	else {
		if (X%L == 0)
		{
			x = X / L;
		}
		else
		{
			x = X / L + 1;
		}

		if (Y%L == 0)
		{
			y = -1 * Y / L;
		}
		else
		{
			y = -1 * Y / L + 1;
		}

		cout << 1 + x + 1 + y << endl;
	}

}
0