#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 ull mod=998244353; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; const int M=1000005; int n,q; ull a[M]; int main(){ cin>>n>>q; ull H=0; a[1]=1; map m; m[0]=0; vi b; for(int i=2;i>c; if(c=='!'){ ull l,r,k; cin>>l>>r>>k; H+=(a[r]-a[l])*k; if(m.find(H)==m.end()) m[H]=i+1; } else cout<