結果

問題 No.297 カードの数式
ユーザー papinianus
提出日時 2016-09-05 13:41:13
言語 PHP
(843.2)
結果
RE  
(最新)
AC  
(最初)
実行時間 -
コード長 1,562 bytes
コンパイル時間 2,881 ms
コンパイル使用メモリ 30,868 KB
実行使用メモリ 31,640 KB
最終ジャッジ日時 2024-12-23 07:54:17
合計ジャッジ時間 4,966 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 22 RE * 1
権限があれば一括ダウンロードができます
コンパイルメッセージ
No syntax errors detected in Main.php

ソースコード

diff #

<?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, "");
        $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;
}
0