#include #include #include #include #include #include #include #include #include using namespace std; #define maxn 1005 typedef __int64 ll; const int _K=50268147,_B=6082187,_P=100000007; int _X; inline int get_rand(int _l,int _r){ _X=((long long)_K*_X+_B)%_P; return _X%(_r-_l+1)+_l; } int n,m,k,seed; int x[1000006],y[1000006]; bool flag1[1000006],flag2[1000006]; void Init(){ scanf("%d%d%d%d",&n,&m,&k,&seed); _X=seed; for (int i=1;i<=k;++i) { x[i]=get_rand(1,n), flag1[x[i]]=1; y[i]=get_rand(1,m); flag2[y[i]]=1; } } int main() { int T; scanf("%d",&T); while(T--) { memset(flag1,0,sizeof(flag1)); memset(flag2,0,sizeof(flag2)); ll ans1=0,ans2=0; Init(); for(int i=1;i<=n;i++) if(flag1[i]==0) ans1++; for(int i=1;i<=m;i++) if(flag2[i]==0) ans2++; printf("%I64d %I64d\n",ans1,ans2); } }