結果

問題 No.20 砂漠のオアシス
ユーザー こるこる
提出日時 2017-02-17 17:30:32
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 16 ms / 5,000 ms
コード長 2,772 bytes
コンパイル時間 750 ms
コンパイル使用メモリ 76,928 KB
実行使用メモリ 4,880 KB
最終ジャッジ日時 2023-08-03 08:13:20
合計ジャッジ時間 1,764 ms
ジャッジサーバーID
(参考情報)
judge15 / judge13
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,380 KB
testcase_01 AC 2 ms
4,384 KB
testcase_02 AC 1 ms
4,384 KB
testcase_03 AC 3 ms
4,384 KB
testcase_04 AC 2 ms
4,384 KB
testcase_05 AC 15 ms
4,880 KB
testcase_06 AC 15 ms
4,720 KB
testcase_07 AC 15 ms
4,764 KB
testcase_08 AC 16 ms
4,816 KB
testcase_09 AC 16 ms
4,820 KB
testcase_10 AC 1 ms
4,380 KB
testcase_11 AC 2 ms
4,380 KB
testcase_12 AC 2 ms
4,380 KB
testcase_13 AC 2 ms
4,380 KB
testcase_14 AC 3 ms
4,384 KB
testcase_15 AC 3 ms
4,384 KB
testcase_16 AC 4 ms
4,384 KB
testcase_17 AC 4 ms
4,384 KB
testcase_18 AC 4 ms
4,384 KB
testcase_19 AC 5 ms
4,384 KB
testcase_20 AC 2 ms
4,384 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<iostream>
#include<string>
#include<vector>
#include<set>
#include<algorithm>
#include<queue>
#include<functional>
#define ll long long
#define PLL pair<ll,ll>
#define VS vector<string>
#define VL vector<ll>
#define rep(i,a) for (ll i=0;i<a;i++)
#define nrep(i,n,a) for (ll i=n;i<a;i++)
#define INF 1145141919810
#define VMIN(vec) *std::max_element(vec.begin(),vec.end())
#define VMIN(vec) *std::max_element(vec.begin(),vec.end())
#define TS(n) to_string(n)

using namespace std;

struct NODE {
	ll level, dist ,x ,y;
};

bool operator< (const NODE &node1, const NODE &node2) { return node1.dist < node2.dist; }
bool operator> (const NODE &node1, const NODE &node2) { return node1.dist > node2.dist; }

NODE nodes[210][210];
bool flag[210][210];

void update(priority_queue<NODE ,vector<NODE> ,greater<NODE> > &pq,NODE node,ll x, ll y) {
	//cout << "update:" << x << " " << y << flag[x][y]<<endl;
	ll cost = node.dist + nodes[x][y].level;
	if ( nodes[x][y].dist > cost) {
		nodes[x][y].dist = cost;
		if (!flag[x][y]) {
			flag[x][y] = true;
			pq.push(nodes[x][y]);
			//cout << "update_pq_size=" << pq.size() << endl;
		}
	}
}

int main() {
	ll N, V, Ox, Oy;
	cin >> N >> V >> Oy >> Ox;
	rep(i, N) rep(j, N) {
		cin >> nodes[i][j].level;
		nodes[i][j].dist = INF;
		nodes[i][j].x = i; nodes[i][j].y = j; flag[i][j] = false;
	}
	priority_queue<NODE, vector<NODE>, greater<NODE> > pq;
	nodes[0][0].dist = 0;
	pq.push(nodes[0][0]);
	NODE node;
	while (!pq.empty()) {
		node = pq.top(); pq.pop();
		//cout << node.x << " " << node.y << endl;
		flag[node.x][node.y] = false;
		if (node.x > 0) { update(pq, node, node.x - 1, node.y); }
		if (node.x < N - 1) { update(pq, node, node.x + 1, node.y); }
		if (node.y > 0) { update(pq, node, node.x, node.y - 1); }
		if (node.y < N - 1) { update(pq, node, node.x, node.y + 1); }
		//cout << "main_pq_size=" << pq.size() << endl;
	}ll start_to_end = V - nodes[N - 1][N - 1].dist;
	if (nodes[N-1][N-1].dist<V){
		cout << "YES" << endl;
		return 0;
	}
	if (Ox == 0 && Oy == 0){
		cout << "NO" << endl;
		return 0;
	}
	ll start_to_O = (V - nodes[Ox - 1][Oy - 1].dist)*2;

	rep(i, N) rep(j, N) nodes[i][j].dist = INF;
	nodes[Ox - 1][Oy - 1].dist = 0;
	pq.push(nodes[Ox - 1][Oy - 1]);
	while (!pq.empty()) {
		node = pq.top(); pq.pop();
		//cout << node.x << " " << node.y << endl;
		flag[node.x][node.y] = false;
		if (node.x > 0) { update(pq, node, node.x - 1, node.y); }
		if (node.x < N - 1) { update(pq, node, node.x + 1, node.y); }
		if (node.y > 0) { update(pq, node, node.x, node.y - 1); }
		if (node.y < N - 1) { update(pq, node, node.x, node.y + 1); }
		//cout << "main_pq_size=" << pq.size() << endl;
	}
	if (nodes[N-1][N-1].dist<start_to_O){
		cout << "YES" << endl;
	}
	else{
		cout << "NO" << endl;
	}
	return 0;
}
0