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; } int to_i(dchar c) { if (c.isDigit) { return cast(int)(c - '0'); } else { return cast(int)(10 + c - 'a'); } } import std.bigint; void main() { auto s = format("%x", BigInt(readln.chomp)); long ans = 0; auto M = new int[16]; foreach (int t; 0 .. 16) { import core.bitop; M[t] = popcnt(t); } foreach (c; s) { ans += M[to_i(c)]; } ans -= (to_i(s.back) & 1); writeln(ans); }