import std.stdio; import std.range; import std.array; import std.string; import std.conv; import std.typecons; import std.algorithm; import std.container; import std.typecons; import std.random; import core.time; auto t() { enum ZERO = [0, 0, 0, 1]; int[] arr = ZERO.dup; foreach (i; 4..10^^6 + 1) { int v = 0; foreach (j; 0..4) { v += arr[i - j - 1]; v %= 17; } auto brr = (arr[i-3..i] ~ v).idup; if (brr == ZERO) { return arr[0..$-3].idup; } arr ~= v; } return arr.idup; } void main() { auto T = t; stderr.writeln = T.length; int q = readln.chomp.to!int; foreach (i; 0..q) { long n = readln.chomp.to!ulong - 1; n %= T.length; T[n].writeln; } }