結果
| 問題 |
No.297 カードの数式
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-01-25 15:41:23 |
| 言語 | PHP (843.2) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,561 bytes |
| コンパイル時間 | 890 ms |
| コンパイル使用メモリ | 32,404 KB |
| 実行使用メモリ | 33,168 KB |
| 最終ジャッジ日時 | 2024-12-23 09:24:16 |
| 合計ジャッジ時間 | 2,773 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 RE * 1 |
| other | AC * 15 WA * 3 RE * 5 |
コンパイルメッセージ
No syntax errors detected in Main.php
ソースコード
<?php
$null = trim(fgets(STDIN));
$cards = explode(" ", trim(fgets(STDIN)));
$plus = 0;
$minus = 0;
$nums = [];
foreach($cards as $card) {
if($card=="+") {
$plus++;
} else if($card=="-") {
$minus++;
} else {
$nums[] = $card;
}
}
echo getMax($nums, $plus, $minus)." ".getMin($nums, $plus, $minus).PHP_EOL;
function getMax($nums, $plus, $minus)
{
sort($nums);
$form = "";
while($minus) {
$num = array_shift($nums);
$form = " - ".$num.$form;
$minus--;
}
while($plus) {
$num = array_shift($nums);
$form = " + ".$num.$form;
$plus--;
}
$form = implode("", array_reverse($nums)).$form;
eval("\$ans = $form;");
return $ans;
}
function getMin($nums, $plus, $minus)
{
$form = "";
sort($nums);
if($minus) {
while($plus) {
$num = array_shift($nums);
$form .= $num." + ";
$plus--;
}
while($minus) {
$num = array_shift($nums);
$form .= $num." - ";
$minus--;
}
$form .= implode("", array_reverse($nums));
} else {
$branches = array_fill(0, $plus+1, 0);
$i=0;
while(!is_null(($num = array_shift($nums)))) {
if($num!=0)$branches[$i] .= (string)$num;
$i = ($i+1) % ($plus+1);
}
$form = implode(" + ",$branches);
}
$form = preg_replace("/[\s^]0+[1-9]/","",$form);
eval("\$ans = $form;");
return $ans;
}