Submission #1833459
Source Code Expand
#include <iostream>
#include <sstream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <ctime>
#include <cstring>
#include <string>
#include <vector>
#include <stack>
#include <queue>
#include <deque>
#include <map>
#include <set>
#include <bitset>
#include <numeric>
#include <utility>
#include <iomanip>
#include <algorithm>
#include <functional>
using namespace std;
#define COUT(x) cout << #x << " = " << (x) << " (L" << __LINE__ << ")" << endl
#define EACH(i, s) for (__typeof__((s).begin()) i = (s).begin(); i != (s).end(); ++i)
template<class T> inline bool chmax(T& a, T b) { if (a < b) { a = b; return 1; } return 0; }
template<class T> inline bool chmin(T& a, T b) { if (a > b) { a = b; return 1; } return 0; }
template<class T1, class T2> ostream& operator << (ostream &s, pair<T1,T2> P)
{ return s << '<' << P.first << ", " << P.second << '>'; }
template<class T> ostream& operator << (ostream &s, vector<T> P)
{ for (int i = 0; i < P.size(); ++i) { if (i > 0) { s << " "; } s << P[i]; } return s; }
template<class T> ostream& operator << (ostream &s, vector<vector<T> > P)
{ for (int i = 0; i < P.size(); ++i) { s << endl << P[i]; } return s << endl; }
template<class T1, class T2> ostream& operator << (ostream &s, map<T1,T2> P)
{ EACH(it, P) { s << "<" << it->first << "->" << it->second << "> "; } return s << endl; }
int N;
int ng[3];
bool dp[310][110];
int main() {
while (cin >> N) {
for (int i = 0; i < 3; ++i) cin >> ng[i];
memset(dp, 0, sizeof(dp));
dp[0][0] = true;
for (int i = 0; i <= N; ++i) {
bool ok = true;
for (int j = 0; j < 3; ++j) if (i == ng[j]) ok = false;
if (!ok) continue;
for (int j = 1; j <= 100; ++j) {
if (i - 1 >= 0) dp[i][j] |= dp[i-1][j-1];
if (i - 2 >= 0) dp[i][j] |= dp[i-2][j-1];
if (i - 3 >= 0) dp[i][j] |= dp[i-3][j-1];
//if (dp[i][j]) cout << i << ", " << j << ": " << dp[i][j] << endl;
}
}
bool res = false;
for (int j = 0; j <= 100; ++j) if (dp[N][j]) res = true;
if (res) puts("YES");
else puts("NO");
}
}
Submission Info
| Submission Time | |
|---|---|
| Task | C - 123引き算 |
| User | drken |
| Language | C++14 (GCC 5.4.1) |
| Score | 100 |
| Code Size | 2307 Byte |
| Status | AC |
| Exec Time | 2 ms |
| Memory | 256 KiB |
Judge Result
| Set Name | All | ||
|---|---|---|---|
| Score / Max Score | 100 / 100 | ||
| Status |
|
| Set Name | Test Cases |
|---|---|
| All | sample_01.txt, sample_02.txt, sample_03.txt, test_143_142_141_140.txt, test_1_1_2_3.txt, test_1_2_3_4.txt, test_200_200_2_3.txt, test_231_77_78_80.txt, test_235_124_126_125.txt, test_253_45_47_48.txt, test_297_223_224_225.txt, test_297_294_292_290.txt, test_297_297_30_83.txt, test_297_3_43_72.txt, test_298_125_123_124.txt, test_298_293_295_291.txt, test_298_298_4_8.txt, test_298_36_72_98.txt, test_298_55_3_43.txt, test_298_92_91_295.txt, test_299_200_151_65.txt, test_299_240_35_154.txt, test_299_300_299_298.txt, test_299_33_242_151.txt, test_299_56_57_58.txt, test_299_66_132_198.txt, test_300_271_44_68.txt, test_300_299_298_296.txt, test_300_30_99_183.txt, test_300_4_5_6.txt, test_84_34_64_36.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| sample_01.txt | AC | 2 ms | 256 KiB |
| sample_02.txt | AC | 1 ms | 256 KiB |
| sample_03.txt | AC | 1 ms | 256 KiB |
| test_143_142_141_140.txt | AC | 1 ms | 256 KiB |
| test_1_1_2_3.txt | AC | 1 ms | 256 KiB |
| test_1_2_3_4.txt | AC | 1 ms | 256 KiB |
| test_200_200_2_3.txt | AC | 1 ms | 256 KiB |
| test_231_77_78_80.txt | AC | 1 ms | 256 KiB |
| test_235_124_126_125.txt | AC | 1 ms | 256 KiB |
| test_253_45_47_48.txt | AC | 1 ms | 256 KiB |
| test_297_223_224_225.txt | AC | 1 ms | 256 KiB |
| test_297_294_292_290.txt | AC | 1 ms | 256 KiB |
| test_297_297_30_83.txt | AC | 1 ms | 256 KiB |
| test_297_3_43_72.txt | AC | 1 ms | 256 KiB |
| test_298_125_123_124.txt | AC | 1 ms | 256 KiB |
| test_298_293_295_291.txt | AC | 1 ms | 256 KiB |
| test_298_298_4_8.txt | AC | 1 ms | 256 KiB |
| test_298_36_72_98.txt | AC | 1 ms | 256 KiB |
| test_298_55_3_43.txt | AC | 1 ms | 256 KiB |
| test_298_92_91_295.txt | AC | 1 ms | 256 KiB |
| test_299_200_151_65.txt | AC | 1 ms | 256 KiB |
| test_299_240_35_154.txt | AC | 1 ms | 256 KiB |
| test_299_300_299_298.txt | AC | 1 ms | 256 KiB |
| test_299_33_242_151.txt | AC | 1 ms | 256 KiB |
| test_299_56_57_58.txt | AC | 1 ms | 256 KiB |
| test_299_66_132_198.txt | AC | 1 ms | 256 KiB |
| test_300_271_44_68.txt | AC | 1 ms | 256 KiB |
| test_300_299_298_296.txt | AC | 1 ms | 256 KiB |
| test_300_30_99_183.txt | AC | 1 ms | 256 KiB |
| test_300_4_5_6.txt | AC | 1 ms | 256 KiB |
| test_84_34_64_36.txt | AC | 1 ms | 256 KiB |