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 N = BigInt(readln.chomp); auto s = format("%x", N / 2); int ans = 0; foreach (c; s) { int t = 0; if (c.isDigit) { t = cast(int)(c - '0'); } else { t = cast(int)(10 + c - 'a'); } while (t > 0) { ans += t & 1; t >>= 1; } } writeln(ans); }