結果
問題 | No.7 プライムナンバーゲーム |
ユーザー |
|
提出日時 | 2015-06-11 08:19:43 |
言語 | PHP (843.2) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,184 bytes |
コンパイル時間 | 3,502 ms |
コンパイル使用メモリ | 32,016 KB |
実行使用メモリ | 32,656 KB |
最終ジャッジ日時 | 2024-07-06 15:33:00 |
合計ジャッジ時間 | 8,114 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 13 WA * 4 |
コンパイルメッセージ
No syntax errors detected in Main.php
ソースコード
<?php define("NOT_REACHED", 0); define("REACHED", 3); define("REACH_EVEN", 1); define("REACH_ODD", 2); $starttime = microtime(TRUE); $n = trim(fgets(STDIN)); $prime_array = array(); for ( $i=2; $i<=$n; $i++ ) { if ( is_prime($i) ) { $prime_array[] = $i; } } $result = array_fill(0, $n+1, NOT_REACHED); $result[$n] = REACH_EVEN; for ( $i=$n; $i>=0; $i-- ) { if ( $result[$i] === NOT_REACHED ) { continue; } for ( $j=0; $j<count($prime_array); $j++ ) { if ( $i-$prime_array[$j] < 0 ) { continue; } switch ( $result[$i] ) { case REACH_EVEN: $result[$i-$prime_array[$j]] = $result[$i-$prime_array[$j]] | REACH_ODD; break; case REACH_ODD: $result[$i-$prime_array[$j]] = $result[$i-$prime_array[$j]] | REACH_EVEN; break; case REACHED: default: break; } } } if ( (($result[0] | $result[1]) == REACH_EVEN) || (($result[0] | $result[1]) == REACHED) ) { echo 'Win'.PHP_EOL; } else { echo 'Lose'.PHP_EOL; } function is_prime($number) { for ( $i=2; $i<=sqrt($number); $i++ ) { if ( !($number % $i) ) { return FALSE; } } return TRUE; } $exectime = microtime(TRUE) - $starttime; fprintf(STDERR,"%f seconds\n", $exectime);