#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const int inf=1<<30; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-8; const ll mod=1e9+7; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; int n; vi a; int main(){ cin>>n; a=vi(n+1,-1); a[1]=1; queue

q; q.push({1,1}); while(!q.empty()){ P p=q.front(); q.pop(); int d=0,x=p.first,y=p.second+1; for(int i=0;i<30;i++) if(x&1<0&&a[x-d]==-1){ a[x-d]=y; q.push({x-d,y}); } if(x+d<=n&&a[x+d]==-1){ a[x+d]=y; q.push({x+d,y}); } } cout<