結果
| 問題 |
No.447 ゆきこーだーの雨と雪 (2)
|
| ユーザー |
|
| 提出日時 | 2016-12-01 23:19:52 |
| 言語 | PHP (843.2) |
| 結果 |
AC
|
| 実行時間 | 374 ms / 2,000 ms |
| コード長 | 2,656 bytes |
| コンパイル時間 | 480 ms |
| コンパイル使用メモリ | 30,836 KB |
| 実行使用メモリ | 34,576 KB |
| 最終ジャッジ日時 | 2024-11-27 16:37:09 |
| 合計ジャッジ時間 | 5,569 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 25 |
コンパイルメッセージ
No syntax errors detected in Main.php
ソースコード
<?php
$problemCount = trim(fgets(STDIN));
$ranks = array_fill(0, $problemCount,1);
$problems = explode(' ', trim(fgets(STDIN)));
$posts = trim(fgets(STDIN));
$scores = [];
$board = new scoreboard();
for(;$posts;$posts--)
{
list($name, $problemCode) = explode(' ', trim(fgets(STDIN)));
if(!isset($scores[$name]))
{
$scores[$name] = new scorenote($name, $problemCount);
}
$problemID = getID($problemCode);
$stars = $problems[$problemID];
$rank = $ranks[$problemID]++;
$scores[$name]->setScore($problemID, calcScore($stars, $rank));
$board->upsert($name, $scores[$name]->getSum());
}
foreach($board->getOrder() as $i => $name)
{
echo ($i+1).' '.$scores[$name]->toString().PHP_EOL;
}
function getID($char)
{
$alpha = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ?';
return strpos($alpha, $char);
}
function calcScore($stars, $rank)
{
return floor((50 * $stars) + ((50 * $stars) / (0.8 + (0.2 * $rank))));
}
class scoreboard
{
private $table;
private $members;
public function __construct()
{
$this->members = [];
$this->table = [];
}
public function upsert($name, $sum)
{
if($this->inMember($name))
{
array_splice($this->table, $this->members[$name], 1);
}
else
{
$this->members[$name] = count($this->members);
}
for($i = $this->members[$name];$i;$i--)
{
$prev = $i - 1;
if($this->table[$prev][1] >= $sum)
{
break;
}
}
array_splice($this->table, $i ,0, [[$name, $sum]]);
$this->members = array_flip(array_column($this->table, 0));
}
public function getOrder()
{
return array_column($this->table, 0);
}
private function inMember($name)
{
return isset($this->members[$name]);
}
}
class scorenote
{
private $name;
private $scores;
private $sum;
public function __construct($name, $count)
{
$this->name = $name;
$this->scores = array_fill(0, $count, 0);
$this->sum = 0;
}
public function getName()
{
return $this->name;
}
public function getSum()
{
return $this->sum;
}
public function toString()
{
$res = $this->name.' ';
foreach($this->scores as $score)
{
$res .= $score.' ';
}
$res .= $this->sum;
return $res;
}
public function setScore($problemId, $score)
{
$this->scores[$problemId] = $score;
$this->sum += $score;
}
}