結果
| 問題 |
No.107 モンスター
|
| コンテスト | |
| ユーザー |
kuroi_13
|
| 提出日時 | 2017-03-24 11:48:28 |
| 言語 | Perl (5.40.0) |
| 結果 |
AC
|
| 実行時間 | 131 ms / 5,000 ms |
| コード長 | 712 bytes |
| コンパイル時間 | 189 ms |
| コンパイル使用メモリ | 5,760 KB |
| 実行使用メモリ | 17,408 KB |
| 最終ジャッジ日時 | 2024-07-06 01:32:27 |
| 合計ジャッジ時間 | 1,641 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 21 |
コンパイルメッセージ
Main.pl syntax OK
ソースコード
use strict;
use warnings;
my $m_num = <>;
my @mons = split ' ', <>;
my %point = (pres => 100, max => 100);
my @dp;
for(my $i = 0; $i < 1<<$m_num; $i++){
$dp[$i] = [0, 0];
}
$dp[0] = [100, 100];
my $ni = 0;
for(my $i = 0; $i < 1<<$m_num; $i++){
next if($dp[$i][0] < 1);
for my $j (0..$m_num-1){
next if(($i>>$j) % 2);
my @np = @{$dp[$i]};
if(0 < $mons[$j]){
$np[0] += $mons[$j];
$np[0] = $np[1] < $np[0] ? $np[1]: $np[0];
}else{
if($np[0] + $mons[$j] > 0){
$np[0] += $mons[$j];
$np[1] += 100;
}else{
$np[0] = 0;
}
}
$ni = $i | 1 << $j;
$dp[$ni] = $dp[$ni][0] < $np[0] ? \@np : $dp[$ni];
}
}
print $dp[(1<<$m_num)-1][0];
kuroi_13