import std.algorithm; import std.array; import std.ascii; import std.container; import std.conv; import std.math; import std.numeric; import std.range; import std.stdio; import std.string; import std.typecons; void log(A...)(A arg) { stderr.writeln(arg); } int size(T)(in T s) { return cast(int)s.length; } import std.bigint; void main() { auto s = format("%x", BigInt(readln.chomp) / 2); long ans = 0; auto M = new int[16]; foreach (int t; 0 .. 16) { import core.bitop; M[t] = popcnt(t); } foreach (c; s) { int t = 0; if (c.isDigit) { t = cast(int)(c - '0'); } else { t = cast(int)(10 + c - 'a'); } ans += M[t]; } writeln(ans); }