#include using namespace std; 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],l[1000006],r[1000006]; void Init(){ scanf("%d%d%d%d",&n,&m,&k,&seed); _X=seed; memset(l,0,sizeof(x)); memset(r,0,sizeof(y)); for (int i=1;i<=k;++i) { x[i]=get_rand(1,n); l[x[i]]++; y[i]=get_rand(1,m); r[y[i]]++; } } int main() { int T,p,q; scanf("%d", &T); while(T--) { Init(); p=0;q=0; for(int i=1;i<=n;i++) if(l[i]==0) p++; for(int i=1;i<=m;i++) if(r[i]==0) q++; printf("%d %d\n", p, q); } return 0; }