結果
問題 | No.7 プライムナンバーゲーム |
ユーザー | cww |
提出日時 | 2016-12-05 07:45:08 |
言語 | C++14 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 280 ms / 5,000 ms |
コード長 | 1,505 bytes |
コンパイル時間 | 1,626 ms |
コンパイル使用メモリ | 176,364 KB |
実行使用メモリ | 394,496 KB |
最終ジャッジ日時 | 2024-10-01 15:50:49 |
合計ジャッジ時間 | 7,157 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 275 ms
394,240 KB |
testcase_01 | AC | 273 ms
394,240 KB |
testcase_02 | AC | 278 ms
394,496 KB |
testcase_03 | AC | 272 ms
394,240 KB |
testcase_04 | AC | 267 ms
394,240 KB |
testcase_05 | AC | 280 ms
394,240 KB |
testcase_06 | AC | 268 ms
394,240 KB |
testcase_07 | AC | 267 ms
394,240 KB |
testcase_08 | AC | 275 ms
394,240 KB |
testcase_09 | AC | 272 ms
394,368 KB |
testcase_10 | AC | 272 ms
394,240 KB |
testcase_11 | AC | 272 ms
394,240 KB |
testcase_12 | AC | 270 ms
394,368 KB |
testcase_13 | AC | 270 ms
394,240 KB |
testcase_14 | AC | 272 ms
394,368 KB |
testcase_15 | AC | 277 ms
394,368 KB |
testcase_16 | AC | 277 ms
394,240 KB |
ソースコード
#include <bits/stdc++.h> using namespace std; struct cww{cww(){ios::sync_with_stdio(false);cin.tie(0);}}star; int N; vector<int> P; vector<vector<int>> visit( 10001, vector<int>(10001, -1 ) );//<---初期化!!! void prime( int N ) { for( int i = 2; i <= N; i++ ) { bool flag = true; for( int j = 2; j * j <= i; j++ ) { if( i % j == 0 ) { flag = false; break; } } if( flag ) { P.emplace_back( i ); } } reverse( P.begin(), P.end() ); } bool dfs( const int T, const int N ) { //0 か 1 を受け取ったのが先手番だったらtrueを返す( = Win ) if( N == 0 || N == 1 ) { return T == 0 ? 1 : 0; } //visit が 0 以上だったら訪問済 if( visit[ T ][ N ] >= 0 ) { //記録を返す return visit[ T ][ N ]; } if ( T == 0 ) { for( const auto &x : P ) { if( N - x >= 0 ) { //T, N に対しての戻り値を記憶 visit[ T ][ N ] = dfs( 1, N - x ); //先手勝ち(1/true)が1つでもあれば先手勝ち(true) if( visit[ T ][ N ] ) return 1; } } return 0; } else { for( const auto &x : P ) { if( N - x >= 0 ) { //T, N に対しての戻り値を記憶 visit[ T ][ N ] = dfs( 0, N - x ); //1つでも負け(0/false)があったら負け(false) if( !visit[ T ][ N ] ) return 0; } } return 1; } } int main() { cin >> N; //要素数リサイズ visit.resize( N ); visit.shrink_to_fit(); prime( N ); cout << ( dfs( 0, N ) ? "Win" : "Lose" ) << endl; return 0; }