Submission #2123017


Source Code Expand

#include <iostream>
#include <utility>
#include <algorithm>
#define llint long long
#define inf ((llint)1e18)

using namespace std;

llint R, C, N;
pair< pair<llint, llint>, llint > RC[100005], CR[100005];

llint row_parent[100005], row_dif[100005];
llint col_parent[100005], col_dif[100005];
llint min_row[100005], min_col[100005];

llint root(llint parent[], llint dif[], int i)
{
	if(parent[i] == i) return i;
	
	root(parent, dif, parent[i]);
	dif[i] = dif[parent[i]] + dif[i];
	return parent[i] = parent[parent[i]];
}

bool same(llint parent[], llint dif[], int i, int j)
{
	return root(parent, dif, i) == root(parent, dif, j);
}

void unite(llint parent[], llint dif[], int i, int j, llint val)
{
	int root_i = root(parent, dif, i), root_j = root(parent, dif, j);
	if(root_i == root_j) return;
	
	llint x = dif[j] - val - dif[i];
	parent[root_i] = root_j;
	dif[root_i] = x;
}

int main(void)
{
	cin >> R >> C >> N;
	llint r, c, a;
	for(int i = 0; i < N; i++){
		cin >> r >> c >> a;
		RC[i] = make_pair(make_pair(r, c), a);
		CR[i] = make_pair(make_pair(c, r), a);
	}
	sort(RC, RC + N);
	sort(CR, CR + N);
	
	for(int i = 1; i <= R; i++) row_parent[i] = i;
	for(int i = 1; i <= C; i++) col_parent[i] = i;
	
	int prev = -1;
	for(int i = 0; i < N; i++){
		if(RC[i].first.first == prev){
			int pc = RC[i-1].first.second, cc = RC[i].first.second;
			if(same(col_parent, col_dif, pc, cc)){
				if(col_dif[cc] - col_dif[pc] != RC[i].second - RC[i-1].second){
					cout << "No" << endl;
					return 0;
				}
			}
			unite(col_parent, col_dif, pc, cc, RC[i].second - RC[i-1].second);
		}
		prev = RC[i].first.first;
	}
	prev = -1;
	for(int i = 0; i < N; i++){
		if(CR[i].first.first == prev){
			int pr = CR[i-1].first.second, cr = CR[i].first.second;
			if(same(row_parent, row_dif, pr, cr)){
				if(row_dif[cr] - row_dif[pr] != CR[i].second - CR[i-1].second){
					cout << "No" << endl;
					return 0;
				}
			}
			unite(row_parent, row_dif, pr, cr, CR[i].second - CR[i-1].second);
		}
		prev = CR[i].first.first;
	}
	
	for(int i = 1; i <= R; i++) min_row[i] = inf;
	for(int i = 1; i <= R; i++){
		root(row_parent, row_dif, i);
		min_row[row_parent[i]] = min(min_row[row_parent[i]], row_dif[i]);
	}
	for(int i = 1; i <= C; i++) min_col[i] = inf;
	for(int i = 1; i <= C; i++){
		root(col_parent, col_dif, i);
		min_col[col_parent[i]] = min(min_col[col_parent[i]], col_dif[i]);
	}
	
	for(int i = 0; i < N; i++){
		if(RC[i].second - row_dif[RC[i].first.first] + min_row[row_parent[RC[i].first.first]] - col_dif[RC[i].first.second] + min_col[row_parent[RC[i].first.second]] < 0){
			cout << "No" << endl;
			return 0;
		}
	}
	
	cout << "Yes" << endl;
	return 0;
}

Submission Info

Submission Time
Task D - Grid and Integers
User leaf1415
Language C++14 (GCC 5.4.1)
Score 0
Code Size 2761 Byte
Status WA
Exec Time 128 ms
Memory 9600 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 0 / 800
Status
AC × 5
AC × 51
WA × 18
Set Name Test Cases
Sample 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt, 0_04.txt
All 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt, 0_04.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 1_20.txt, 1_21.txt, 1_22.txt, 1_23.txt, 1_24.txt, 1_25.txt, 1_26.txt, 1_27.txt, 1_28.txt, 1_29.txt, 1_30.txt, 1_31.txt, 1_32.txt, 1_33.txt, 1_34.txt, 1_35.txt, 1_36.txt, 1_37.txt, 1_38.txt, 1_39.txt, 1_40.txt, 1_41.txt, 1_42.txt, 1_43.txt, 1_44.txt, 1_45.txt, 1_46.txt, 1_47.txt, 1_48.txt, 1_49.txt, 1_50.txt, 1_51.txt, 1_52.txt, 1_53.txt, 1_54.txt, 1_55.txt, 1_56.txt, 1_57.txt, 1_58.txt, 1_59.txt, 1_60.txt, 1_61.txt, 1_62.txt, 1_63.txt
Case Name Status Exec Time Memory
0_00.txt AC 2 ms 6400 KB
0_01.txt AC 2 ms 6400 KB
0_02.txt AC 2 ms 6400 KB
0_03.txt AC 2 ms 6400 KB
0_04.txt AC 2 ms 6400 KB
1_00.txt AC 4 ms 7936 KB
1_01.txt AC 4 ms 7936 KB
1_02.txt AC 4 ms 7936 KB
1_03.txt AC 4 ms 7936 KB
1_04.txt AC 4 ms 7936 KB
1_05.txt AC 2 ms 6400 KB
1_06.txt AC 90 ms 9088 KB
1_07.txt AC 115 ms 9088 KB
1_08.txt AC 93 ms 9600 KB
1_09.txt WA 93 ms 9600 KB
1_10.txt AC 120 ms 9600 KB
1_11.txt AC 121 ms 8064 KB
1_12.txt AC 122 ms 9600 KB
1_13.txt AC 116 ms 8064 KB
1_14.txt AC 127 ms 9600 KB
1_15.txt AC 128 ms 9600 KB
1_16.txt AC 98 ms 9600 KB
1_17.txt WA 112 ms 9600 KB
1_18.txt AC 108 ms 9600 KB
1_19.txt AC 110 ms 9600 KB
1_20.txt WA 77 ms 7424 KB
1_21.txt WA 33 ms 7552 KB
1_22.txt AC 7 ms 6912 KB
1_23.txt WA 72 ms 8320 KB
1_24.txt WA 96 ms 7936 KB
1_25.txt AC 74 ms 7552 KB
1_26.txt WA 9 ms 6656 KB
1_27.txt AC 15 ms 7680 KB
1_28.txt AC 120 ms 8832 KB
1_29.txt WA 38 ms 7552 KB
1_30.txt AC 112 ms 8960 KB
1_31.txt WA 43 ms 8192 KB
1_32.txt WA 99 ms 7680 KB
1_33.txt AC 112 ms 8960 KB
1_34.txt WA 15 ms 7552 KB
1_35.txt AC 110 ms 7936 KB
1_36.txt WA 18 ms 7168 KB
1_37.txt WA 48 ms 6784 KB
1_38.txt WA 82 ms 8576 KB
1_39.txt WA 26 ms 7936 KB
1_40.txt WA 80 ms 8320 KB
1_41.txt WA 40 ms 8320 KB
1_42.txt AC 94 ms 7552 KB
1_43.txt AC 74 ms 8192 KB
1_44.txt AC 100 ms 8192 KB
1_45.txt AC 30 ms 6912 KB
1_46.txt AC 108 ms 8832 KB
1_47.txt AC 39 ms 7552 KB
1_48.txt AC 34 ms 6912 KB
1_49.txt AC 13 ms 7296 KB
1_50.txt AC 63 ms 7296 KB
1_51.txt AC 104 ms 7680 KB
1_52.txt AC 10 ms 7936 KB
1_53.txt AC 18 ms 7936 KB
1_54.txt WA 34 ms 7296 KB
1_55.txt AC 49 ms 6784 KB
1_56.txt AC 73 ms 6912 KB
1_57.txt AC 113 ms 7936 KB
1_58.txt AC 97 ms 8320 KB
1_59.txt AC 8 ms 7552 KB
1_60.txt AC 2 ms 6400 KB
1_61.txt AC 2 ms 6400 KB
1_62.txt AC 2 ms 6400 KB
1_63.txt AC 2 ms 6400 KB