struct xy{
int x;
int y;
xy(){
}
xy(int m){
x=m;
y=m;
}
xy(int x,int y){
this->x=x;
this->y=y;
}
xy operator *(xy&m){return xy(x *m.x,y *m.y);}
xy operator /(xy&m){return xy(x /m.x,y /m.y);}
xy operator %(xy&m){return xy(x %m.x,y %m.y);}
xy operator +(xy&m){return xy(x +m.x,y +m.y);}
xy operator -(xy&m){return xy(x -m.x,y -m.y);}
xy operator <<(xy&m){return xy(x<<m.x,y<<m.y);}
xy operator >>(xy&m){return xy(x>>m.x,y>>m.y);}
xy operator &(xy&m){return xy(x &m.x,y &m.y);}
xy operator |(xy&m){return xy(x |m.x,y |m.y);}
xy operator ^(xy&m){return xy(x ^m.x,y ^m.y);}
xy operator *=(xy&m){x *=m.x;y *=m.y;return *this;}
xy operator /=(xy&m){x /=m.x;y /=m.y;return *this;}
xy operator %=(xy&m){x %=m.x;y %=m.y;return *this;}
xy operator +=(xy&m){x +=m.x;y +=m.y;return *this;}
xy operator -=(xy&m){x -=m.x;y -=m.y;return *this;}
xy operator <<=(xy&m){x<<=m.x;y<<=m.y;return *this;}
xy operator >>=(xy&m){x>>=m.x;y>>=m.y;return *this;}
xy operator &=(xy&m){x &=m.x;y &=m.y;return *this;}
xy operator |=(xy&m){x |=m.x;y |=m.y;return *this;}
xy operator ^=(xy&m){x ^=m.x;y ^=m.y;return *this;}
xy operator *(int m){return xy(x *m,y *m);}
xy operator /(int m){return xy(x /m,y /m);}
xy operator %(int m){return xy(x %m,y %m);}
xy operator +(int m){return xy(x +m,y +m);}
xy operator -(int m){return xy(x -m,y -m);}
xy operator <<(int m){return xy(x<<m,y<<m);}
xy operator >>(int m){return xy(x>>m,y>>m);}
xy