結果
| 問題 | 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);