https://projecteuler.net/problem=18
全てのパスで和を計算して、最大値を得ます。パスは2進数で表せます。左に行くのは0で右は1です。
最新のバージョンでletでwarningが出るようになりました。そのうち使えなくなるそうです。めんどうなのでそのままにしています。
from math import max #################### process #################### fn make_triangle(s: String) -> DynamicVector[DynamicVector[Int]]: var triangle = DynamicVector[DynamicVector[Int]]() try: let v = s.split("\n") for i in range(1, v.size-1): let w = v[i].strip().split(' ') var row = DynamicVector[Int]() for j in range(i): row.push_back(atol(w[j])) triangle.push_back(row) except: pass return triangle fn total(i: Int, tri: DynamicVector[DynamicVector[Int]]) -> Int: let N = tri.size var s = tri[0][0] var y = 0 var j = i for x in range(1, N): let k = j & 1 j >>= 1 if k != 0: y += 1 s += tri[x][y] return s fn f(s: String) -> Int: let tri = make_triangle(s) let N = tri.size var s1 = 0 for i in range(1 << (N-1)): let s2 = total(i, tri) s1 = max(s1, s2) return s1 fn main() raises: let s = """ 75 95 64 17 47 82 18 35 87 10 20 04 82 47 65 19 01 23 75 03 34 88 02 77 73 07 63 67 99 65 04 28 06 16 70 92 41 41 26 56 83 40 80 70 33 41 48 72 33 47 32 37 16 94 29 53 71 44 65 25 43 91 52 97 51 14 70 11 33 28 77 73 17 78 39 68 17 57 91 71 52 38 17 14 91 43 58 50 27 29 48 63 66 04 68 89 53 67 30 73 16 69 87 40 31 04 62 98 27 23 09 70 98 73 93 38 53 60 04 23 """ print(f(String(s)))