Submission #2094300


Source Code Expand

#include <bits/stdc++.h>
using namespace std;

typedef pair<int, int> pii;
typedef long long ll;
typedef vector<int> vi;

#define pb push_back
#define eb emplace_back
#define mp make_pair
#define fi first
#define se second
#define rep(i,n) rep2(i,0,n)
#define rep2(i,m,n) for(int i=m;i<(n);i++)
#define ALL(c) (c).begin(),(c).end()

const ll MOD = 1000000007;
const int MN = 310;

inline void add(ll &x, ll y) { x += y; if (x >= MOD) x -= MOD; }

ll dp[MN][MN][MN];
vector<pii> cond[MN];

bool ok(int r, int i, int j, int k)
{
	bool ok = 1;

	for (pii c : cond[r]) {
		int cnt = 0;
		if (i-1 >= c.fi) {
			++cnt;
		}
		if (j-1 >= c.fi) {
			++cnt;
		}
		if (k-1 >= c.fi) {
			++cnt;
		}
		if (cnt != c.se) {
			return false;
		}
	}
	return true;
}

int main() {
	int N, M;
	cin >> N >> M;

	rep(i, M) {
		int l, r, x;
		cin >> l >> r >> x;
		--l; --r;
		cond[r].eb(l, x);
	}

	dp[0][0][0] = 1;
	ll ret = 0;

	rep(i, N+1) {
		rep(j, N+1) {
			rep(k, N+1) {
				int nx = max({i, j, k});
				if (nx == N) {
					add(ret, dp[i][j][k]);
					continue;
				}

				if (ok(nx, nx+1, j, k)) {
					add(dp[nx+1][j][k], dp[i][j][k]);
				}

				if (ok(nx, i, nx+1, k)) {
					add(dp[i][nx+1][k], dp[i][j][k]);
				}

				if (ok(nx, i, j, nx+1)) {
					add(dp[i][j][nx+1], dp[i][j][k]);
				}				
			}
		}
	}

	cout << ret << endl;

	return 0;
}

Submission Info

Submission Time
Task E - RGB Sequence
User satashun
Language C++14 (GCC 5.4.1)
Score 800
Code Size 1420 Byte
Status AC
Exec Time 536 ms
Memory 227712 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 800 / 800
Status
AC × 4
AC × 47
Set Name Test Cases
Sample 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt
All 0_00.txt, 0_01.txt, 0_02.txt, 0_03.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
Case Name Status Exec Time Memory
0_00.txt AC 2 ms 2304 KB
0_01.txt AC 2 ms 2304 KB
0_02.txt AC 1 ms 256 KB
0_03.txt AC 2 ms 4352 KB
1_00.txt AC 388 ms 223232 KB
1_01.txt AC 273 ms 225408 KB
1_02.txt AC 346 ms 227584 KB
1_03.txt AC 389 ms 225408 KB
1_04.txt AC 414 ms 227328 KB
1_05.txt AC 295 ms 225408 KB
1_06.txt AC 333 ms 227584 KB
1_07.txt AC 335 ms 225408 KB
1_08.txt AC 396 ms 225408 KB
1_09.txt AC 371 ms 225536 KB
1_10.txt AC 347 ms 223360 KB
1_11.txt AC 335 ms 223360 KB
1_12.txt AC 282 ms 219264 KB
1_13.txt AC 372 ms 227584 KB
1_14.txt AC 355 ms 225536 KB
1_15.txt AC 428 ms 225408 KB
1_16.txt AC 394 ms 225408 KB
1_17.txt AC 295 ms 227584 KB
1_18.txt AC 332 ms 225408 KB
1_19.txt AC 338 ms 225408 KB
1_20.txt AC 374 ms 223360 KB
1_21.txt AC 326 ms 227712 KB
1_22.txt AC 332 ms 225536 KB
1_23.txt AC 411 ms 225408 KB
1_24.txt AC 303 ms 225536 KB
1_25.txt AC 343 ms 227584 KB
1_26.txt AC 307 ms 221312 KB
1_27.txt AC 328 ms 225536 KB
1_28.txt AC 397 ms 225408 KB
1_29.txt AC 303 ms 225536 KB
1_30.txt AC 316 ms 223360 KB
1_31.txt AC 384 ms 221312 KB
1_32.txt AC 273 ms 225408 KB
1_33.txt AC 298 ms 227584 KB
1_34.txt AC 304 ms 221312 KB
1_35.txt AC 314 ms 225536 KB
1_36.txt AC 224 ms 217216 KB
1_37.txt AC 279 ms 225408 KB
1_38.txt AC 319 ms 227584 KB
1_39.txt AC 280 ms 227584 KB
1_40.txt AC 536 ms 227584 KB
1_41.txt AC 393 ms 227584 KB
1_42.txt AC 223 ms 225536 KB