結果
問題 | No.107 モンスター |
ユーザー |
![]() |
提出日時 | 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];