#include using namespace std; #define REP(i,a,b) for(i=a;i'9')break;*x=(*x)*10+k-'0';}if(m)(*x)=-(*x);} void writer(int x, char c){int s=0,m=0;char f[10];if(x<0)m=1,x=-x;while(x)f[s++]=x%10,x/=10;if(!s)f[s++]=0;if(m)mypc('-');while(s--)mypc(f[s]+'0');mypc(c);} int N; int q[100010], q_st, q_size, dist[100010], bt[100010]; int main(){ int i, j, k; reader(&N); rep(i,N+1) dist[i] = -1; dist[1] = 1; q_st = q_size = 0; q[q_st+q_size++] = 1; bt[0] = 0; REP(i,1,N+1) bt[i] = bt[i&(i-1)]+1; while(q_size){ k = q[q_st++]; q_size--; if(k-bt[k] >= 1 && dist[k-bt[k]]==-1){ dist[k-bt[k]] = dist[k] + 1; q[q_st+q_size++] = k-bt[k]; } if(k+bt[k] <= N && dist[k+bt[k]]==-1){ dist[k+bt[k]] = dist[k] + 1; q[q_st+q_size++] = k+bt[k]; } } writer(dist[N],'\n'); return 0; }