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
AC × 31
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