#include #include #include using namespace std; typedef long long LL; const int MAXN=1e6+9; 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]; 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), y[i]=get_rand(1,m); } bool vis[MAXN],falg[MAXN]; void init() { for(int i=1;i<=n;++i) vis[i]=false; for(int i=1;i<=m;++i) falg[i]=false; } int main() { int T; scanf("%d",&T); while(T--) { Init(); init(); int c=0,l=0; for(int i=1;i<=k;++i) { vis[x[i]]=true; falg[y[i]]=true; } for(int i=1;i<=n;++i) if(!vis[i]) c++; for(int i=1;i<=m;++i) if(!falg[i]) l++; printf("%d %d\n",c,l); } return 0; }