結果

問題 No.90 品物の並び替え
コンテスト
ユーザー kou_kkk
提出日時 2024-04-24 10:09:11
言語 Nim
(2.2.8)
コンパイル:
nim --nimcache=~ --hints:off -o:a.out -d:release cpp _filename_
実行:
./a.out
結果
AC  
実行時間 122 ms / 5,000 ms
コード長 556 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 3,613 ms
コンパイル使用メモリ 70,216 KB
実行使用メモリ 6,400 KB
最終ジャッジ日時 2026-05-06 22:28:11
合計ジャッジ時間 5,671 ms
ジャッジサーバーID
(参考情報)
judge2_1 / judge3_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 9
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import algorithm, math, sequtils, strutils

let
  nm = stdin.readLine.split.map parseInt
  n = nm[0]
  m = nm[1]
  inputs = (0 ..< m).mapIt stdin.readLine.split.map parseInt
var
  g = n.succ.newSeqWith newSeq[(int, int)](succ n)
  
for v in inputs:
  g[v[0]].add (v[1], v[2])


proc fn(xs: seq[int]): int =
  result = 0
  var
    points = 0.repeat n.succ
  for x in xs:
    result += points[x]
    for (b, p) in g[x]:
      points[b] += p


var
  xs = (0 ..< n).toSeq
  maximum = fn xs

while nextPermutation xs:
  maximum = xs.fn.max maximum

echo maximum
0