結果

問題 No.2606 Mirror Relay
ユーザー 👑 seekworserseekworser
提出日時 2024-09-09 02:32:18
言語 Nim
(2.2.0)
結果
AC  
実行時間 316 ms / 2,000 ms
コード長 4,061 bytes
コンパイル時間 3,744 ms
コンパイル使用メモリ 66,460 KB
実行使用メモリ 83,932 KB
最終ジャッジ日時 2024-09-09 02:32:26
合計ジャッジ時間 8,036 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
6,816 KB
testcase_01 AC 2 ms
6,940 KB
testcase_02 AC 2 ms
6,940 KB
testcase_03 AC 2 ms
6,944 KB
testcase_04 AC 2 ms
6,944 KB
testcase_05 AC 2 ms
6,944 KB
testcase_06 AC 3 ms
6,944 KB
testcase_07 AC 2 ms
6,944 KB
testcase_08 AC 2 ms
6,944 KB
testcase_09 AC 2 ms
6,940 KB
testcase_10 AC 2 ms
6,944 KB
testcase_11 AC 3 ms
6,940 KB
testcase_12 AC 2 ms
6,940 KB
testcase_13 AC 2 ms
6,940 KB
testcase_14 AC 2 ms
6,940 KB
testcase_15 AC 2 ms
6,940 KB
testcase_16 AC 2 ms
6,940 KB
testcase_17 AC 2 ms
6,940 KB
testcase_18 AC 2 ms
6,940 KB
testcase_19 AC 4 ms
6,944 KB
testcase_20 AC 4 ms
6,944 KB
testcase_21 AC 3 ms
6,944 KB
testcase_22 AC 3 ms
6,944 KB
testcase_23 AC 3 ms
6,940 KB
testcase_24 AC 3 ms
6,940 KB
testcase_25 AC 3 ms
6,944 KB
testcase_26 AC 3 ms
6,940 KB
testcase_27 AC 4 ms
6,944 KB
testcase_28 AC 3 ms
6,944 KB
testcase_29 AC 2 ms
6,940 KB
testcase_30 AC 2 ms
6,944 KB
testcase_31 AC 2 ms
6,940 KB
testcase_32 AC 2 ms
6,944 KB
testcase_33 AC 2 ms
6,940 KB
testcase_34 AC 2 ms
6,944 KB
testcase_35 AC 2 ms
6,940 KB
testcase_36 AC 2 ms
6,944 KB
testcase_37 AC 2 ms
6,940 KB
testcase_38 AC 2 ms
6,940 KB
testcase_39 AC 25 ms
7,296 KB
testcase_40 AC 24 ms
7,168 KB
testcase_41 AC 24 ms
7,296 KB
testcase_42 AC 24 ms
7,296 KB
testcase_43 AC 24 ms
7,296 KB
testcase_44 AC 24 ms
7,296 KB
testcase_45 AC 25 ms
7,296 KB
testcase_46 AC 25 ms
7,296 KB
testcase_47 AC 25 ms
7,296 KB
testcase_48 AC 24 ms
7,296 KB
testcase_49 AC 76 ms
25,408 KB
testcase_50 AC 90 ms
25,928 KB
testcase_51 AC 93 ms
28,188 KB
testcase_52 AC 70 ms
21,172 KB
testcase_53 AC 97 ms
27,608 KB
testcase_54 AC 82 ms
25,156 KB
testcase_55 AC 143 ms
43,732 KB
testcase_56 AC 78 ms
25,200 KB
testcase_57 AC 74 ms
23,868 KB
testcase_58 AC 103 ms
30,532 KB
testcase_59 AC 26 ms
7,424 KB
testcase_60 AC 25 ms
7,424 KB
testcase_61 AC 25 ms
7,296 KB
testcase_62 AC 25 ms
7,296 KB
testcase_63 AC 26 ms
7,680 KB
testcase_64 AC 25 ms
7,296 KB
testcase_65 AC 26 ms
7,424 KB
testcase_66 AC 25 ms
7,296 KB
testcase_67 AC 25 ms
7,296 KB
testcase_68 AC 25 ms
7,168 KB
testcase_69 AC 316 ms
83,932 KB
testcase_70 AC 2 ms
6,940 KB
testcase_71 AC 1 ms
6,944 KB
testcase_72 AC 1 ms
6,940 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import macros;macro ImportExpand(s:untyped):untyped = parseStmt($s[2])
# verification-helper: PROBLEM https://onlinejudge.u-aizu.ac.jp/problems/NTL_1_E
import strutils
import sequtils
import algorithm
ImportExpand "cplib/collections/palindromic_tree.nim" <=== "when not declared CPLIB_COLLECTIONS_PALINDROMIC_TREE:\n    const CPLIB_COLLECTIONS_PALINDROMIC_TREE* = 1\n    import sequtils\n    import algorithm\n    type PalindromicTreeNode* = object\n        link: seq[ref PalindromicTreeNode]\n        suffix_link: ref PalindromicTreeNode\n        len, count, id: int\n\n    type PalindromicTree* = object\n        amax: int\n        nodes: seq[ref PalindromicTreeNode]\n\n    proc len*(node: PalindromicTreeNode): int = node.len\n    proc count*(node: PalindromicTreeNode): int = node.count\n    proc id*(node: PalindromicTreeNode): int = node.id\n    proc suffix_link*(node: PalindromicTreeNode): ref PalindromicTreeNode = node.suffix_link\n    proc link*(node: PalindromicTreeNode): seq[ref PalindromicTreeNode] = node.link\n    proc nodes*(pt: PalindromicTree): seq[ref PalindromicTreeNode] = pt.nodes\n\n    proc newPalindromicTreeNode(pt: var PalindromicTree, amax, len: int): ref PalindromicTreeNode =\n        result = new PalindromicTreeNode\n        result[].link = newSeq[ref PalindromicTreeNode](amax)\n        result[].suffix_link = nil\n        result[].len = len\n        result[].count = 0\n        result[].id = pt.nodes.len\n        pt.nodes.add(result)\n\n    proc init(amax: int): PalindromicTree =\n        discard result.newPalindromicTreeNode(amax, -1)\n        discard result.newPalindromicTreeNode(amax, 0)\n        result.amax = amax\n        result.nodes[1][].suffix_link = result.nodes[0]\n\n\n    proc initPalindromicTree*(a: seq[int], amax: int = -1): PalindromicTree =\n        var amax = amax\n        if amax < 0: amax = a.max\n        result = init(amax)\n        proc find_longest(pos: int, node: ref PalindromicTreeNode): ref PalindromicTreeNode =\n            var ln = pos - node[].len - 1\n            if ln >= 0 and a[ln] == a[pos]:\n                return node\n            return find_longest(pos, node[].suffix_link)\n        var current_node = result.nodes[0]\n        for i in 0..<a.len:\n            current_node = find_longest(i, current_node)\n            if current_node[].link[a[i]] == nil:\n                current_node[].link[a[i]] = result.newPalindromicTreeNode(amax, current_node[].len + 2)\n            if current_node == result.nodes[0]:\n                current_node[].link[a[i]][].suffix_link = result.nodes[1]\n            else:\n                current_node[].link[a[i]][].suffix_link = find_longest(i, current_node[].suffix_link)[].link[a[i]]\n            current_node = current_node[].link[a[i]]\n            current_node[].count += 1\n\n    proc initPalindromicTree*(s: string, c: char = 'a'): PalindromicTree =\n        return initPalindromicTree(s.mapIt(int(it) - int(c)), 26)\n\n    proc get_palindrome*(pt: PalindromicTree, node: ref PalindromicTreeNode): seq[int] =\n        if node == pt.nodes[0] or node == pt.nodes[1]: return newSeq[int](0)\n        var ans = newSeq[int](0)\n        proc dfs(x: ref PalindromicTreeNode): bool =\n            if x == node: return true\n            for i in 0..<pt.amax:\n                if x[].link[i] == nil: continue\n                if dfs(x[].link[i]):\n                    ans.add(i)\n                    return true\n            return false\n        discard dfs(pt.nodes[0])\n        discard dfs(pt.nodes[1])\n        for i in ans.len..<node[].len:\n            ans.add(ans[node[].len-1-i])\n        return ans\n\n    proc update_count*(pt: PalindromicTree) =\n        for node in pt.nodes[1..<pt.nodes.len].reversed:\n            node[].suffix_link[].count += node[].count\n"

var s = stdin.readLine.reversed.join("")
var pt = initPalindromicTree(s)
pt.update_count

var score = newSeqWith(pt.nodes.len, 0)
for i in 1..<pt.nodes.len:
    var node = pt.nodes[i]
    score[i] = score[node[].suffix_link[].id] + node[].count * node[].len
echo score.max
0