結果
| 問題 |
No.297 カードの数式
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-01-25 16:02:36 |
| 言語 | PHP (843.2) |
| 結果 |
AC
|
| 実行時間 | 48 ms / 1,000 ms |
| コード長 | 1,566 bytes |
| コンパイル時間 | 2,472 ms |
| コンパイル使用メモリ | 30,840 KB |
| 実行使用メモリ | 31,636 KB |
| 最終ジャッジ日時 | 2024-12-26 02:33:47 |
| 合計ジャッジ時間 | 4,484 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 23 |
コンパイルメッセージ
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])/","$2",$form);
eval("\$ans = $form;");
return $ans;
}