My solutions to 2018's advent of code
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
Ce dépôt est archivé. Vous pouvez voir les fichiers et le cloner, mais vous ne pouvez pas pousser ni ouvrir de ticket/demande d'ajout.

elfcode.nim 2.1KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import strutils, tables
  2. type
  3. instr* = tuple[op: string, a,b,c: int]
  4. instructionSet* = tuple[ipr: int, instructions: seq[instr]]
  5. let ops* = {
  6. "addi": proc(regs: seq[int], a,b: int): int = regs[a] + b,
  7. "addr": proc(regs: seq[int], a,b: int): int = regs[a] + regs[b],
  8. "muli": proc(regs: seq[int], a,b: int): int = regs[a] * b,
  9. "mulr": proc(regs: seq[int], a,b: int): int = regs[a] * regs[b],
  10. "bani": proc(regs: seq[int], a,b: int): int = regs[a] and b,
  11. "banr": proc(regs: seq[int], a,b: int): int = regs[a] and regs[b],
  12. "bori": proc(regs: seq[int], a,b: int): int = regs[a] or b,
  13. "borr": proc(regs: seq[int], a,b: int): int = regs[a] or regs[b],
  14. "seti": proc(regs: seq[int], a,b: int): int = a,
  15. "setr": proc(regs: seq[int], a,b: int): int = regs[a],
  16. "gtir": proc(regs: seq[int], a,b: int): int = cast[int](a > regs[b]),
  17. "gtri": proc(regs: seq[int], a,b: int): int = cast[int](regs[a] > b),
  18. "gtrr": proc(regs: seq[int], a,b: int): int = cast[int](regs[a] > regs[b]),
  19. "eqir": proc(regs: seq[int], a,b: int): int = cast[int](a == regs[b]),
  20. "eqri": proc(regs: seq[int], a,b: int): int = cast[int](regs[a] == b),
  21. "eqrr": proc(regs: seq[int], a,b: int): int = cast[int](regs[a] == regs[b]),
  22. }.toTable
  23. proc readInstructions*(input: seq[string]): instructionSet =
  24. for line in input:
  25. var parts = line.split(' ')
  26. if parts[0] == "#ip":
  27. result.ipr = parts[1].parseInt
  28. else:
  29. result.instructions.add((parts[0], parts[1].parseInt, parts[2].parseInt, parts[3].parseInt))
  30. proc ip*(instructionSet: instructionSet, registers: seq[int]): int {.inline.} =
  31. registers[instructionSet.ipr]
  32. proc currentInstr*(instructionSet: instructionSet, registers: seq[int]): instr {.inline.} =
  33. instructionSet.instructions[instructionSet.ip(registers)]
  34. proc step*(instructionSet: instructionSet, registers: var seq[int]) {.inline.} =
  35. let instr = instructionSet.currentInstr(registers)
  36. registers[instr.c] = ops[instr.op](registers, instr.a, instr.b)
  37. registers[instructionSet.ipr].inc