結果
| 問題 |
No.7 プライムナンバーゲーム
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-06-11 12:27:28 |
| 言語 | PHP (843.2) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,036 bytes |
| コンパイル時間 | 70 ms |
| コンパイル使用メモリ | 30,836 KB |
| 実行使用メモリ | 31,484 KB |
| 最終ジャッジ日時 | 2024-07-06 15:35:01 |
| 合計ジャッジ時間 | 3,672 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 12 WA * 5 |
コンパイルメッセージ
No syntax errors detected in Main.php
ソースコード
<?php
define("NOT_REACHED", 0);
define("REACHED", 3);
define("REACH_EVEN", 1);
define("REACH_ODD", 2);
$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 ) {
break;
}
switch ( $result[$i] ) {
case REACH_EVEN:
$result[$i-$prime_array[$j]] |= REACH_ODD;
break;
case REACH_ODD:
$result[$i-$prime_array[$j]] |= REACH_EVEN;
break;
case REACHED:
$result[$i-$prime_array[$j]] |= REACHED;
break;
default:
break;
}
}
}
if ( ($result[0] == REACH_ODD) || ($result[1] == REACH_ODD) ) {
echo 'Lose'.PHP_EOL;
}
else {
echo 'Win'.PHP_EOL;
}
function is_prime($number) {
for ( $i=2; $i<=sqrt($number); $i++ ) {
if ( !($number % $i) ) {
return FALSE;
}
}
return TRUE;
}