結果
問題 | No.994 ばらばらコイン |
ユーザー | ynishi2015 |
提出日時 | 2020-02-21 21:50:38 |
言語 | PHP (843.2) |
結果 |
WA
|
実行時間 | - |
コード長 | 3,247 bytes |
コンパイル時間 | 342 ms |
コンパイル使用メモリ | 32,272 KB |
実行使用メモリ | 61,296 KB |
最終ジャッジ日時 | 2024-10-08 21:36:15 |
合計ジャッジ時間 | 3,457 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | WA | - |
testcase_01 | WA | - |
testcase_02 | WA | - |
testcase_03 | WA | - |
testcase_04 | WA | - |
testcase_05 | WA | - |
testcase_06 | WA | - |
testcase_07 | WA | - |
testcase_08 | WA | - |
testcase_09 | WA | - |
testcase_10 | WA | - |
testcase_11 | WA | - |
testcase_12 | WA | - |
testcase_13 | WA | - |
testcase_14 | WA | - |
testcase_15 | WA | - |
testcase_16 | WA | - |
testcase_17 | AC | 40 ms
32,272 KB |
testcase_18 | WA | - |
testcase_19 | AC | 39 ms
32,404 KB |
testcase_20 | WA | - |
testcase_21 | WA | - |
testcase_22 | WA | - |
コンパイルメッセージ
No syntax errors detected in Main.php
ソースコード
<?php list($n, $k) = ints(); $distance = array_fill(1, $n, PHP_INT_MAX); for($i = 0; $i < $n-1; $i++){ list($f, $t) = ints(); $G[$f][] = $t; $G[$t][] = $f; } $current = [1]; $distance[1] = 0; $d = 0; while($current){ $d++; $next = []; foreach($current as $c){ foreach($G[$c] as $n){ if($distance[$n] == PHP_INT_MAX){ $distance[$n] = $d; $next[] = $n; } } } $current = $next; } $count = array_fill(0,$n+1, 0); foreach($distance as $d){ if($d != PHP_INT_MAX)$count[$d]++; } $ans = 0; foreach($count as $dist => $count){ if($dist < PHP_INT_MAX){ for($i = 0; $i < $count; $i++){ if($k == 0)break 2; $k--; $ans+=$dist; } } } if($k > 0){ echo $k-1,"\n"; }else{ echo $ans,"\n"; } exit; o($count); o($G); function str(){ return trim(fgets(STDIN)); } function ints(){ return array_map("intval", explode(" ", trim(fgets(STDIN)))); } function int(){ return intval(trim(fgets(STDIN))); } function chmax(&$a,$b){if($a<$b){$a=$b;return 1;}return 0;} function chmin(&$a,$b){if($a>$b){$a=$b;return 1;}return 0;} function o(...$val){ if(count($val)==1)$val = array_shift($val); $trace = debug_backtrace(); echo $trace[0]['line'].")"; if(is_array($val)){ if(count($val) == 0){ echo "empty array"; }elseif(!is_array(current($val))){ echo "array: "; echo implode(" ", addIndex($val))."\n"; }else{ echo "array:array\n"; if(isCleanArray($val)){ foreach($val as $row)echo implode(" ", addIndex($row))."\n"; }else{ foreach($val as $i => $row)echo "[".$i."] ".implode(" ", addIndex($row))."\n"; } } }else{ echo $val."\n"; } } function addIndex($val){ if(!isCleanArray($val)){ $val = array_map(function($k, $v){return $k.":".$v;}, array_keys($val), $val); } return $val; } function isCleanArray($array){ $clean = true; $i = 0; foreach($array as $k => $v){ if($k != $i++)$clean = false; } return $clean; } /** * 座圧対象の配列を渡すと以下の値を返す * ・圧縮された配列 * ・復元用のMap * ・圧縮用のMap **/ function atsu($array){ $a = array_flip($array); $fuku = array_flip($a); sort($fuku); $atsu = array_flip($fuku); foreach($array as $i => $val)$array[$i] = $atsu[$val]; return [$array, $fuku, $atsu]; } //配列の最大公約数 function gcdAll($array){ $gcd = $array[0]; for($i = 1; $i < count($array); $i++){ $gcd = gcd($gcd, $array[$i]); } return $gcd; } //最大公約数 function gcd($m, $n){ if(!$n)return $m; return gcd($n, $m % $n); } //配列の最小公倍数 function lcmAll($array){ $lcm = $array[0]; for($i = 1; $i < count($array); $i++){ $lcm = lcm($lcm, $array[$i]); } return $lcm; } //最小公倍数 function lcm($a, $b) { return $a / gcd($a, $b) * $b; } //ビットカウント-1の数を数える function popcount($x){ $con = 0; while ($x) { $x &= $x-1; ++$con; } return $con; }