import java.util.*;
import java.lang.*;
import java.math.*;
import java.io.*;
import static java.
lang.
Math.
*; import static java.
util.
Arrays.
*;
public class A{
Scanner sc
=new Scanner
(System.
in);
int INF=1<<28;
// input
int width, height, n;
int[] ws0, hs0;
// trial
int[] xs, ys;
int[] ws, hs;
int[] ts, ss;
int[] _;
boolean[] us;
int target;
// best
int[] bestXs, bestYs;
int[] bestWs, bestHs;
boolean[] bestUs;
// parameters
int marginX, marginY;
int maxArea;
final double alpha=2.2;
int[] scales;
int nScales;
int scalesOrder;
final int ascending=1, descending=-1;
int[] dx1, dy1;
int[] dx2, dy2;
Xorshift xorShift;
final long timeLimit=4800;
// debug
boolean debug=false, lock=false, draw=false;
long start;
void run(){
start
=System.
currentTimeMillis();
width=sc.nextInt();
height=sc.nextInt();
n=sc.nextInt();
ws0=new int[n];
hs0=new int[n];
for(int i=0; i<n; i++){
ws0[i]=sc.nextInt();
hs0[i]=sc.nextInt();
}
Answer a=solve();
StringBuilder sb=new StringBuilder();
for(int i=0; i<n; i++){
// if x1=y1=x2=y2=-10
// output "-1.0 -1.0 -1.0 -1.0"
sb.append(a.x1[i]/10);
sb.append('.');
sb.append(a.x1[i]%10);
sb.append(' ');
sb.append(a.y1[i]/10);
sb.append('.');
sb.append(a.y1[i]%10);
sb.append(' ');
sb.append(a.x2[i]/10);
sb.append('.');
sb.append(a.x2[i]%10);
sb.append(' ');
sb.append(a.y2[i]/10);
sb.append('.');
sb.append(a.y2[i]%10);
sb.append('\n');
}
println(sb.toString());
}
void load(Param param){
start
=System.
currentTimeMillis();
width=param.w;
height=param.h;
n=param.n;
ws0=param.ws.clone();
hs0=param.hs.clone();
}
void init(){
width*=10;
height*=10;
for(int i=0; i<n; i++){
ws0[i]*=10;
hs0[i]*=10;
}
xs=new int[n];
ys=new int[n];
ws=new int[n];
hs=new int[n];
ts=new int[n];
ss=new int[n];
_=new int[n];
us=new boolean[n];
bestXs=new int[n];
bestYs=new int[n];
bestWs=new int[n];
bestHs=new int[n];
bestUs=new boolean[n];
xorShift=new Xorshift();
}
Answer solve(){
init();
draw=true;
if(n<=15){
solveSmall();
}else{
solveLarge();
}
return output();
}
void solveSmall(){
int[][] scaless=new int[2][];
scaless[0]=new int[]{20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8,
7, 6, 5, 4, 3, 2, 1};
scaless[1]=new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
16, 17, 18, 19, 20};
int[] scalesOrders={descending, ascending};
int nScaless=scaless.length;
dx1=new int[]{0};
dy1=new int[]{0};
dx2=new int[]{0, -1, 0, -1};
dy2=new int[]{0, 0, -1, -1};
int[] maxAreas={width*height/1, width*height/3, width*height/5,
width*height/7, width*height/9};
int nMaxAreas=maxAreas.length;
for(int i=0; i<n; i++){
_[i]=i;
}
int bestSumScore=-INF;
for(int trial=0;; trial++){
maxArea=maxAreas[trial%nMaxAreas];
scales=scaless[(trial/nMaxAreas)%nScaless];
scalesOrder=scalesOrders[(trial/nMaxAreas)%nScaless];
nScales=scales.length;
fill(us, false);
int sumScore=0;
for(int i=0; i<n; i++){
target=i;
sumScore+=step2();
}
if(sumScore>bestSumScore){
bestSumScore=sumScore;
updateBest();
}
shuffleSmall(_);
long end
=System.
currentTimeMillis(); if(end-start>timeLimit){
break;
}
}
}
void solveLarge(){
scales=new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
scalesOrder=ascending;
nScales=scales.length;
dx1=new int[]{0, 0, 0, -1, 1};
dy1=new int[]{0, -1, 1, 0, 0};
dx2=new int[]{0, -1, 0, -1};
dy2=new int[]{0, 0, -1, -1};
int min=min(width, height);
int[] marginXs={min/4, min/5, min/6, width/4, width/5, width/6};
int[] marginYs={min/4, min/5, min/6, height/4, height/5, height/6};
int nMargin=marginXs.length;
maxArea=(int)(alpha*width*height/n);
int bestSumScore=-INF;
for(int trial=0;; trial++){
for(int k=0; k<nMargin; k++){
marginX=marginXs[k];
marginY=marginYs[k];
Pair[] pairs=new Pair[n];
for(int i=0; i<n; i++){
double w=ws0[i];
double h=hs0[i];
// n>25
if(trial>0&&n>25){
w+=xorShift.nextDouble()*width/10;
h+=xorShift.nextDouble()*height/10;
}
pairs[i]=new Pair(i, w/h);
}
sort(pairs);
int index=0;
for(int i=0; i<n/2; i++){
_[index++]=pairs[i].key;
_[index++]=pairs[n-1-i].key;
}
if(n%2==1){
_[index++]=pairs[n/2].key;
}
// n<=25
if(trial>0&&n<=25){
for(int s=0; s<2; s++){
int i=xorShift.nextInt(n);
int j=xorShift.nextInt(n);
int t=_[i];
_[i]=_[j];
_[j]=t;
}
}
fill(us, false);
target=0;
int sumScore;
if(width>height){
sumScore=step1x();
}else{
sumScore=step1y();
}
int from=target;
for(int i=from; i<n; i++){
us[_[i]]=false;
}
for(int i=from; i<n; i++){
target=i;
sumScore+=step2();
long end
=System.
currentTimeMillis(); if(end-start>timeLimit){
return;
}
}
if(sumScore>bestSumScore){
bestSumScore=sumScore;
updateBest();
}
}
}
}
void updateBest(){
System.
arraycopy(xs,
0, bestXs,
0, n
); System.
arraycopy(ys,
0, bestYs,
0, n
); System.
arraycopy(ws,
0, bestWs,
0, n
); System.
arraycopy(hs,
0, bestHs,
0, n
); System.
arraycopy(us,
0, bestUs,
0, n
); }
Answer output(){
int[] x1=new int[n];
int[] y1=new int[n];
int[] x2=new int[n];
int[] y2=new int[n];
// answer.*[i]=*[i]*10
for(int i=0; i<n; i++){
if(bestUs[i]){
x1[i]=bestXs[i];
y1[i]=bestYs[i];
x2[i]=bestXs[i]+bestWs[i];
y2[i]=bestYs[i]+bestHs[i];
}else{
x1[i]=y1[i]=x2[i]=y2[i]=-10;
}
}
return new Answer(x1, y1, x2, y2);
}
int step1x(){
int sumScore=0;
int x=marginX;
int h=height-2*marginY;
for(int i=0; i<n; i++){
target=i;
int s;
if(i%2==0){
s=10*h/hs0[_[i]];
}else{
s=10*h/ws0[_[i]];
}
s=min(s, 20);
s=max(s, 1);
if(i%2==0){
ws[_[i]]=ws0[_[i]]*s/10;
hs[_[i]]=hs0[_[i]]*s/10;
}else{
ws[_[i]]=hs0[_[i]]*s/10;
hs[_[i]]=ws0[_[i]]*s/10;
}
xs[_[i]]=x;
ys[_[i]]=marginY;
ts[_[i]]=i%2;
ss[_[i]]=s;
us[_[i]]=true;
if(ys[_[i]]+hs[_[i]]>height){
ys[_[i]]=0;
if(ys[_[i]]+hs[_[i]]>height){
us[_[i]]=false;
}
}
if(xs[_[i]]+ws[_[i]]>width-marginX){
us[_[i]]=false;
break;
}
x+=ws[_[i]];
if(us[_[i]]){
sumScore+=calcScore();
}
}
return sumScore;
}
int step1y(){
int sumScore=0;
int y=marginY;
int w=width-2*marginX;
for(int i=0; i<n; i++){
target=i;
int s;
if(i%2==0){
s=10*w/hs0[_[i]];
}else{
s=10*w/ws0[_[i]];
}
s=min(s, 20);
s=max(s, 1);
if(i%2==0){
ws[_[i]]=hs0[_[i]]*s/10;
hs[_[i]]=ws0[_[i]]*s/10;
}else{
ws[_[i]]=ws0[_[i]]*s/10;
hs[_[i]]=hs0[_[i]]*s/10;
}
xs[_[i]]=marginX;
ys[_[i]]=y;
ts[_[i]]=(i+1)%2;
ss[_[i]]=s;
us[_[i]]=true;
if(xs[_[i]]+ws[_[i]]>width){
xs[_[i]]=0;
if(xs[_[i]]+ws[_[i]]>width){
us[_[i]]=false;
}
}
if(ys[_[i]]+hs[_[i]]+marginY>height){
us[_[i]]=false;
break;
}
y+=hs[_[i]];
if(us[_[i]]){
sumScore+=calcScore();
}
}
return sumScore;
}
int step2(){
final int e4=10000, e8=100000000;
HashSet<Integer> set=new HashSet<Integer>();
set.add(0);
set.add(width);
set.add(height*e4);
set.add(width+height*e4);
for(int i=0; i<target; i++){
if(!us[_[i]]){
continue;
}
int x=xs[_[i]];
int y=ys[_[i]];
int w=ws[_[i]];
int h=hs[_[i]];
for(int k=0; k<dx1.length; k++){
set.add((x+dx1[k])+(y+dy1[k])*e4);
set.add((x+w+dx1[k])+(y+dy1[k])*e4);
set.add((x+dx1[k])+(y+h+dy1[k])*e4);
set.add((x+w+dx1[k])+(y+h+dy1[k])*e4);
}
}
int index=_[target];
us[index]=false;
ws[index]=min(ws0[index], hs0[index])/10;
hs[index]=min(ws0[index], hs0[index])/10;
ArrayList<Integer> candidate=new ArrayList<Integer>();
for(int p : set){
int x=p%e4;
int y=p/e4;
int bit=0;
for(int i=0; i<dx2.length; i++){
xs[index]=x+dx2[i]*ws[index];
ys[index]=y+dy2[i]*hs[index];
if(check()){
bit|=1<<i;
}
}
if(bit!=0){
candidate.add(p+bit*e8);
}
}
boolean ok=false;
int bestScore=-INF;
int bestX=-1, bestY=-1, bestW=-1, bestH=-1, bestT=-1, bestS=-1;
for(int p : candidate){
int x=p%e4;
int y=p/e4%e4;
int bit=p/e8;
for(int k=0; k<2; k++){
for(int j=0; j<dx2.length; j++){
if((bit>>j&1)==0){
continue;
}
for(int i=0; i<nScales; i++){
if(k==0){
ws[index]=ws0[index]*scales[i]/10;
hs[index]=hs0[index]*scales[i]/10;
}else{
ws[index]=hs0[index]*scales[i]/10;
hs[index]=ws0[index]*scales[i]/10;
}
if(ws[index]*hs[index]>maxArea){
if(scalesOrder==ascending){
break;
}else{
continue;
}
}
xs[index]=x+dx2[j]*ws[index];
ys[index]=y+dy2[j]*hs[index];
ts[index]=k;
ss[index]=scales[i];
if(check()){
int score=calcScore();
ok=true;
if(score>bestScore){
bestScore=score;
bestX=xs[index];
bestY=ys[index];
bestW=ws[index];
bestH=hs[index];
bestT=ts[index];
bestS=ss[index];
}
}else if(scalesOrder==ascending){
break;
}
}
}
}
}
us[index]=false;
if(ok&&(target==0||bestScore>0)){
xs[index]=bestX;
ys[index]=bestY;
ws[index]=bestW;
hs[index]=bestH;
ts[index]=bestT;
ss[index]=bestS;
us[index]=true;
}
return us[index]?bestScore:0;
}
boolean check(){
// determine whether target's position is valid or not
int x=xs[_[target]];
int y=ys[_[target]];
int w=ws[_[target]];
int h=hs[_[target]];
if(x<0||x+w>width||y<0||y+h>height){
return false;
}
for(int i=0; i<target; i++){
if(us[_[i]]&&overlapStrict(xs[_[i]], ws[_[i]], x, w)
&&overlapStrict(ys[_[i]], hs[_[i]], y, h)){
return false;
}
}
return true;
}
int calcScore(){
// assume no rects overlap
int score=0;
int x=xs[_[target]];
int y=ys[_[target]];
int w=ws[_[target]];
int h=hs[_[target]];
int t=ts[_[target]];
for(int i=0; i<target; i++){
if(!us[_[i]]){
continue;
}
int x1=max(xs[_[i]], x);
int x2=min(xs[_[i]]+ws[_[i]], x+w);
int y1=max(ys[_[i]], y);
int y2=min(ys[_[i]]+hs[_[i]], y+h);
if(x1<x2&&y1==y2){
score+=(ts[_[i]]==t?-1:1)*(x2-x1);
}
if(y1<y2&&x1==x2){
score+=(ts[_[i]]==t?-1:1)*(y2-y1);
}
}
return score;
}
int calcScoreAll(){
// assume no rects overlap
int score=0;
for(int i=0; i<n; i++){
if(!us[i]){
continue;
}
for(int j=i+1; j<n; j++){
if(!us[j]){
continue;
}
int x1=max(xs[i], xs[j]);
int x2=min(xs[i]+ws[i], xs[j]+ws[j]);
int y1=max(ys[i], ys[j]);
int y2=min(ys[i]+hs[i], ys[j]+hs[j]);
if(x1<x2&&y1==y2){
score+=(ts[i]==ts[j]?-1:1)*(x2-x1);
}
if(y1<y2&&x1==x2){
score+=(ts[i]==ts[j]?-1:1)*(y2-y1);
}
}
}
return score;
}
boolean overlap(int x1, int w1, int x2, int w2){
return x1<=x2+w2&&x2<=x1+w1;
}
boolean overlapStrict(int x1, int w1, int x2, int w2){
return x1<x2+w2&&x2<x1+w1;
}
void shuffleSmall(int[] is){
for(int i=is.length-1; i>=1; i--){
int j=xorShift.nextInt(i+1);
int t=is[i];
is[i]=is[j];
is[j]=t;
}
}
void shuffleLarge(int[] is, int from){
for(int i=is.length-1; i>=from+1; i--){
int j=xorShift.nextInt(i-from+1)+from;
int t=is[i];
is[i]=is[j];
is[j]=t;
}
}
void lock(){
if(debug){
for(; lock;){
try{
e.printStackTrace();
}
}
lock=true;
}
}
}
}
}
public static void main
(String[] args
){ new A().run();
}
}
class Xorshift{
int x, y, z, w;
public Xorshift(){
x=123456789;
y=362436069;
z=521288629;
w=88675123;
}
public Xorshift(int seed){
x=_(seed, 0);
y=_(x, 1);
z=_(y, 2);
w=_(z, 3);
}
int _(int s, int i){
return 1812433253*(s^(s>>>30))+i+1;
}
// 32bit signed
public int nextInt(){
int t=x^(x<<11);
x=y;
y=z;
z=w;
return w=w^(w>>>19)^t^(t>>>8);
}
// error = O(n*2^-32)
public int nextInt(int n){
return (int)(n*nextDouble());
}
// [0, 1) (53bit)
public double nextDouble(){
int a=nextInt()>>>5, b=nextInt()>>>6;
return (a*67108864.0+b)*(1.0/(1L<<53));
}
}
class Pair implements Comparable<Pair>{
int key;
double value;
Pair(int key, double value){
this.key=key;
this.value=value;
}
@Override
public int compareTo(Pair p){
return Double.
compare(value, p.
value); }
}
class Param{
int w, h, n;
int[] ws, hs;
Param(int w, int h, int n, int[] ws, int[] hs){
this.w=w;
this.h=h;
this.n=n;
this.ws=ws.clone();
this.hs=hs.clone();
}
}
class Answer{
int[] x1, y1, x2, y2;
int n;
Answer(int[] x1, int[] y1, int[] x2, int[] y2){
this.x1=x1.clone();
this.y1=y1.clone();
this.x2=x2.clone();
this.y2=y2.clone();
n=x1.length;
}
}
class Scanner{
eat("");
}
}
try{
return br.readLine();
throw new IOError(e);
}
}
boolean hasNext(){
while(!st.hasMoreTokens()){
if(s==null)
return false;
eat(s);
}
return true;
}
hasNext();
return st.nextToken();
}
int nextInt(){
}
}
import java.util.*;
import java.lang.*;
import java.math.*;
import java.io.*;

import static java.lang.Math.*;
import static java.util.Arrays.*;
import static java.util.Collections.*;

public class A{
	Scanner sc=new Scanner(System.in);

	int INF=1<<28;

	// input
	int width, height, n;
	int[] ws0, hs0;

	// trial
	int[] xs, ys;
	int[] ws, hs;
	int[] ts, ss;
	int[] _;
	boolean[] us;

	int target;

	// best
	int[] bestXs, bestYs;
	int[] bestWs, bestHs;
	boolean[] bestUs;

	// parameters
	int marginX, marginY;
	int maxArea;
	final double alpha=2.2;

	int[] scales;
	int nScales;
	int scalesOrder;
	final int ascending=1, descending=-1;

	int[] dx1, dy1;
	int[] dx2, dy2;

	Xorshift xorShift;

	final long timeLimit=4800;

	// debug
	boolean debug=false, lock=false, draw=false;

	long start;

	void run(){
		start=System.currentTimeMillis();

		width=sc.nextInt();
		height=sc.nextInt();
		n=sc.nextInt();
		ws0=new int[n];
		hs0=new int[n];
		for(int i=0; i<n; i++){
			ws0[i]=sc.nextInt();
			hs0[i]=sc.nextInt();
		}
		Answer a=solve();
		StringBuilder sb=new StringBuilder();
		for(int i=0; i<n; i++){
			// if x1=y1=x2=y2=-10
			// output "-1.0 -1.0 -1.0 -1.0"
			sb.append(a.x1[i]/10);
			sb.append('.');
			sb.append(a.x1[i]%10);
			sb.append(' ');
			sb.append(a.y1[i]/10);
			sb.append('.');
			sb.append(a.y1[i]%10);
			sb.append(' ');
			sb.append(a.x2[i]/10);
			sb.append('.');
			sb.append(a.x2[i]%10);
			sb.append(' ');
			sb.append(a.y2[i]/10);
			sb.append('.');
			sb.append(a.y2[i]%10);
			sb.append('\n');
		}
		println(sb.toString());
	}

	void load(Param param){
		start=System.currentTimeMillis();

		width=param.w;
		height=param.h;
		n=param.n;
		ws0=param.ws.clone();
		hs0=param.hs.clone();
	}

	void init(){
		width*=10;
		height*=10;

		for(int i=0; i<n; i++){
			ws0[i]*=10;
			hs0[i]*=10;
		}

		xs=new int[n];
		ys=new int[n];
		ws=new int[n];
		hs=new int[n];
		ts=new int[n];
		ss=new int[n];
		_=new int[n];
		us=new boolean[n];

		bestXs=new int[n];
		bestYs=new int[n];
		bestWs=new int[n];
		bestHs=new int[n];
		bestUs=new boolean[n];

		xorShift=new Xorshift();
	}

	Answer solve(){
		init();
		draw=true;
		if(n<=15){
			solveSmall();
		}else{
			solveLarge();
		}
		return output();
	}

	void solveSmall(){
		int[][] scaless=new int[2][];
		scaless[0]=new int[]{20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8,
				7, 6, 5, 4, 3, 2, 1};
		scaless[1]=new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
				16, 17, 18, 19, 20};
		int[] scalesOrders={descending, ascending};
		int nScaless=scaless.length;

		dx1=new int[]{0};
		dy1=new int[]{0};
		dx2=new int[]{0, -1, 0, -1};
		dy2=new int[]{0, 0, -1, -1};

		int[] maxAreas={width*height/1, width*height/3, width*height/5,
				width*height/7, width*height/9};
		int nMaxAreas=maxAreas.length;

		for(int i=0; i<n; i++){
			_[i]=i;
		}

		int bestSumScore=-INF;
		for(int trial=0;; trial++){
			maxArea=maxAreas[trial%nMaxAreas];
			scales=scaless[(trial/nMaxAreas)%nScaless];
			scalesOrder=scalesOrders[(trial/nMaxAreas)%nScaless];
			nScales=scales.length;

			fill(us, false);

			int sumScore=0;
			for(int i=0; i<n; i++){
				target=i;
				sumScore+=step2();
			}

			if(sumScore>bestSumScore){
				bestSumScore=sumScore;
				updateBest();
			}

			shuffleSmall(_);

			long end=System.currentTimeMillis();
			if(end-start>timeLimit){
				break;
			}
		}
	}

	void solveLarge(){
		scales=new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
		scalesOrder=ascending;
		nScales=scales.length;

		dx1=new int[]{0, 0, 0, -1, 1};
		dy1=new int[]{0, -1, 1, 0, 0};
		dx2=new int[]{0, -1, 0, -1};
		dy2=new int[]{0, 0, -1, -1};

		int min=min(width, height);
		int[] marginXs={min/4, min/5, min/6, width/4, width/5, width/6};
		int[] marginYs={min/4, min/5, min/6, height/4, height/5, height/6};
		int nMargin=marginXs.length;

		maxArea=(int)(alpha*width*height/n);

		int bestSumScore=-INF;
		for(int trial=0;; trial++){
			for(int k=0; k<nMargin; k++){
				marginX=marginXs[k];
				marginY=marginYs[k];

				Pair[] pairs=new Pair[n];
				for(int i=0; i<n; i++){
					double w=ws0[i];
					double h=hs0[i];
					// n>25
					if(trial>0&&n>25){
						w+=xorShift.nextDouble()*width/10;
						h+=xorShift.nextDouble()*height/10;
					}
					pairs[i]=new Pair(i, w/h);
				}
				sort(pairs);
				int index=0;
				for(int i=0; i<n/2; i++){
					_[index++]=pairs[i].key;
					_[index++]=pairs[n-1-i].key;
				}
				if(n%2==1){
					_[index++]=pairs[n/2].key;
				}

				// n<=25
				if(trial>0&&n<=25){
					for(int s=0; s<2; s++){
						int i=xorShift.nextInt(n);
						int j=xorShift.nextInt(n);
						int t=_[i];
						_[i]=_[j];
						_[j]=t;
					}
				}

				fill(us, false);
				target=0;

				int sumScore;
				if(width>height){
					sumScore=step1x();
				}else{
					sumScore=step1y();
				}
				int from=target;

				for(int i=from; i<n; i++){
					us[_[i]]=false;
				}

				for(int i=from; i<n; i++){
					target=i;
					sumScore+=step2();
					long end=System.currentTimeMillis();
					if(end-start>timeLimit){
						return;
					}
				}

				if(sumScore>bestSumScore){
					bestSumScore=sumScore;
					updateBest();
				}
			}
		}
	}

	void updateBest(){
		System.arraycopy(xs, 0, bestXs, 0, n);
		System.arraycopy(ys, 0, bestYs, 0, n);
		System.arraycopy(ws, 0, bestWs, 0, n);
		System.arraycopy(hs, 0, bestHs, 0, n);
		System.arraycopy(us, 0, bestUs, 0, n);
	}

	Answer output(){
		int[] x1=new int[n];
		int[] y1=new int[n];
		int[] x2=new int[n];
		int[] y2=new int[n];

		// answer.*[i]=*[i]*10
		for(int i=0; i<n; i++){
			if(bestUs[i]){
				x1[i]=bestXs[i];
				y1[i]=bestYs[i];
				x2[i]=bestXs[i]+bestWs[i];
				y2[i]=bestYs[i]+bestHs[i];
			}else{
				x1[i]=y1[i]=x2[i]=y2[i]=-10;
			}
		}
		return new Answer(x1, y1, x2, y2);
	}

	int step1x(){
		int sumScore=0;
		int x=marginX;
		int h=height-2*marginY;
		for(int i=0; i<n; i++){
			target=i;
			int s;
			if(i%2==0){
				s=10*h/hs0[_[i]];
			}else{
				s=10*h/ws0[_[i]];
			}
			s=min(s, 20);
			s=max(s, 1);
			if(i%2==0){
				ws[_[i]]=ws0[_[i]]*s/10;
				hs[_[i]]=hs0[_[i]]*s/10;
			}else{
				ws[_[i]]=hs0[_[i]]*s/10;
				hs[_[i]]=ws0[_[i]]*s/10;
			}
			xs[_[i]]=x;
			ys[_[i]]=marginY;
			ts[_[i]]=i%2;
			ss[_[i]]=s;
			us[_[i]]=true;
			if(ys[_[i]]+hs[_[i]]>height){
				ys[_[i]]=0;
				if(ys[_[i]]+hs[_[i]]>height){
					us[_[i]]=false;
				}
			}
			if(xs[_[i]]+ws[_[i]]>width-marginX){
				us[_[i]]=false;
				break;
			}
			x+=ws[_[i]];
			if(us[_[i]]){
				sumScore+=calcScore();
			}
		}
		return sumScore;
	}

	int step1y(){
		int sumScore=0;
		int y=marginY;
		int w=width-2*marginX;
		for(int i=0; i<n; i++){
			target=i;
			int s;
			if(i%2==0){
				s=10*w/hs0[_[i]];
			}else{
				s=10*w/ws0[_[i]];
			}
			s=min(s, 20);
			s=max(s, 1);
			if(i%2==0){
				ws[_[i]]=hs0[_[i]]*s/10;
				hs[_[i]]=ws0[_[i]]*s/10;
			}else{
				ws[_[i]]=ws0[_[i]]*s/10;
				hs[_[i]]=hs0[_[i]]*s/10;
			}
			xs[_[i]]=marginX;
			ys[_[i]]=y;
			ts[_[i]]=(i+1)%2;
			ss[_[i]]=s;
			us[_[i]]=true;
			if(xs[_[i]]+ws[_[i]]>width){
				xs[_[i]]=0;
				if(xs[_[i]]+ws[_[i]]>width){
					us[_[i]]=false;
				}
			}
			if(ys[_[i]]+hs[_[i]]+marginY>height){
				us[_[i]]=false;
				break;
			}
			y+=hs[_[i]];
			if(us[_[i]]){
				sumScore+=calcScore();
			}
		}
		return sumScore;
	}

	int step2(){
		final int e4=10000, e8=100000000;

		HashSet<Integer> set=new HashSet<Integer>();
		set.add(0);
		set.add(width);
		set.add(height*e4);
		set.add(width+height*e4);
		for(int i=0; i<target; i++){
			if(!us[_[i]]){
				continue;
			}
			int x=xs[_[i]];
			int y=ys[_[i]];
			int w=ws[_[i]];
			int h=hs[_[i]];
			for(int k=0; k<dx1.length; k++){
				set.add((x+dx1[k])+(y+dy1[k])*e4);
				set.add((x+w+dx1[k])+(y+dy1[k])*e4);
				set.add((x+dx1[k])+(y+h+dy1[k])*e4);
				set.add((x+w+dx1[k])+(y+h+dy1[k])*e4);
			}
		}

		int index=_[target];
		us[index]=false;

		ws[index]=min(ws0[index], hs0[index])/10;
		hs[index]=min(ws0[index], hs0[index])/10;

		ArrayList<Integer> candidate=new ArrayList<Integer>();
		for(int p : set){
			int x=p%e4;
			int y=p/e4;
			int bit=0;
			for(int i=0; i<dx2.length; i++){
				xs[index]=x+dx2[i]*ws[index];
				ys[index]=y+dy2[i]*hs[index];
				if(check()){
					bit|=1<<i;
				}
			}
			if(bit!=0){
				candidate.add(p+bit*e8);
			}
		}

		boolean ok=false;
		int bestScore=-INF;
		int bestX=-1, bestY=-1, bestW=-1, bestH=-1, bestT=-1, bestS=-1;

		for(int p : candidate){
			int x=p%e4;
			int y=p/e4%e4;
			int bit=p/e8;
			for(int k=0; k<2; k++){
				for(int j=0; j<dx2.length; j++){
					if((bit>>j&1)==0){
						continue;
					}
					for(int i=0; i<nScales; i++){
						if(k==0){
							ws[index]=ws0[index]*scales[i]/10;
							hs[index]=hs0[index]*scales[i]/10;
						}else{
							ws[index]=hs0[index]*scales[i]/10;
							hs[index]=ws0[index]*scales[i]/10;
						}
						if(ws[index]*hs[index]>maxArea){
							if(scalesOrder==ascending){
								break;
							}else{
								continue;
							}
						}

						xs[index]=x+dx2[j]*ws[index];
						ys[index]=y+dy2[j]*hs[index];
						ts[index]=k;
						ss[index]=scales[i];

						if(check()){
							int score=calcScore();
							ok=true;
							if(score>bestScore){
								bestScore=score;
								bestX=xs[index];
								bestY=ys[index];
								bestW=ws[index];
								bestH=hs[index];
								bestT=ts[index];
								bestS=ss[index];
							}
						}else if(scalesOrder==ascending){
							break;
						}
					}
				}
			}
		}

		us[index]=false;
		if(ok&&(target==0||bestScore>0)){
			xs[index]=bestX;
			ys[index]=bestY;
			ws[index]=bestW;
			hs[index]=bestH;
			ts[index]=bestT;
			ss[index]=bestS;
			us[index]=true;
		}

		return us[index]?bestScore:0;
	}

	boolean check(){
		// determine whether target's position is valid or not
		int x=xs[_[target]];
		int y=ys[_[target]];
		int w=ws[_[target]];
		int h=hs[_[target]];
		if(x<0||x+w>width||y<0||y+h>height){
			return false;
		}
		for(int i=0; i<target; i++){
			if(us[_[i]]&&overlapStrict(xs[_[i]], ws[_[i]], x, w)
					&&overlapStrict(ys[_[i]], hs[_[i]], y, h)){
				return false;
			}
		}
		return true;
	}

	int calcScore(){
		// assume no rects overlap
		int score=0;
		int x=xs[_[target]];
		int y=ys[_[target]];
		int w=ws[_[target]];
		int h=hs[_[target]];
		int t=ts[_[target]];
		for(int i=0; i<target; i++){
			if(!us[_[i]]){
				continue;
			}
			int x1=max(xs[_[i]], x);
			int x2=min(xs[_[i]]+ws[_[i]], x+w);

			int y1=max(ys[_[i]], y);
			int y2=min(ys[_[i]]+hs[_[i]], y+h);

			if(x1<x2&&y1==y2){
				score+=(ts[_[i]]==t?-1:1)*(x2-x1);
			}
			if(y1<y2&&x1==x2){
				score+=(ts[_[i]]==t?-1:1)*(y2-y1);
			}
		}
		return score;
	}

	int calcScoreAll(){
		// assume no rects overlap
		int score=0;
		for(int i=0; i<n; i++){
			if(!us[i]){
				continue;
			}
			for(int j=i+1; j<n; j++){
				if(!us[j]){
					continue;
				}
				int x1=max(xs[i], xs[j]);
				int x2=min(xs[i]+ws[i], xs[j]+ws[j]);

				int y1=max(ys[i], ys[j]);
				int y2=min(ys[i]+hs[i], ys[j]+hs[j]);

				if(x1<x2&&y1==y2){
					score+=(ts[i]==ts[j]?-1:1)*(x2-x1);
				}
				if(y1<y2&&x1==x2){
					score+=(ts[i]==ts[j]?-1:1)*(y2-y1);
				}
			}
		}
		return score;
	}

	boolean overlap(int x1, int w1, int x2, int w2){
		return x1<=x2+w2&&x2<=x1+w1;
	}

	boolean overlapStrict(int x1, int w1, int x2, int w2){
		return x1<x2+w2&&x2<x1+w1;
	}

	void shuffleSmall(int[] is){
		for(int i=is.length-1; i>=1; i--){
			int j=xorShift.nextInt(i+1);
			int t=is[i];
			is[i]=is[j];
			is[j]=t;
		}
	}

	void shuffleLarge(int[] is, int from){
		for(int i=is.length-1; i>=from+1; i--){
			int j=xorShift.nextInt(i-from+1)+from;
			int t=is[i];
			is[i]=is[j];
			is[j]=t;
		}
	}

	void lock(){
		if(debug){
			for(; lock;){
				try{
					Thread.sleep(2);
				}catch(InterruptedException e){
					e.printStackTrace();
				}
			}
			lock=true;
		}
	}

	void println(String s){
		System.out.println(s);
	}

	void print(String s){
		System.out.print(s);
	}

	void debug(Object... os){
		System.err.println(Arrays.deepToString(os));
	}

	public static void main(String[] args){
		new A().run();
	}

}

class Xorshift{

	int x, y, z, w;

	public Xorshift(){
		x=123456789;
		y=362436069;
		z=521288629;
		w=88675123;
	}

	public Xorshift(int seed){
		x=_(seed, 0);
		y=_(x, 1);
		z=_(y, 2);
		w=_(z, 3);
	}

	int _(int s, int i){
		return 1812433253*(s^(s>>>30))+i+1;
	}

	// 32bit signed
	public int nextInt(){
		int t=x^(x<<11);
		x=y;
		y=z;
		z=w;
		return w=w^(w>>>19)^t^(t>>>8);
	}

	// error = O(n*2^-32)
	public int nextInt(int n){
		return (int)(n*nextDouble());
	}

	// [0, 1) (53bit)
	public double nextDouble(){
		int a=nextInt()>>>5, b=nextInt()>>>6;
		return (a*67108864.0+b)*(1.0/(1L<<53));
	}

}

class Pair implements Comparable<Pair>{
	int key;
	double value;

	Pair(int key, double value){
		this.key=key;
		this.value=value;
	}

	@Override
	public int compareTo(Pair p){
		return Double.compare(value, p.value);
	}
}

class Param{
	int w, h, n;
	int[] ws, hs;

	Param(int w, int h, int n, int[] ws, int[] hs){
		this.w=w;
		this.h=h;
		this.n=n;
		this.ws=ws.clone();
		this.hs=hs.clone();
	}
}

class Answer{
	int[] x1, y1, x2, y2;
	int n;

	Answer(int[] x1, int[] y1, int[] x2, int[] y2){
		this.x1=x1.clone();
		this.y1=y1.clone();
		this.x2=x2.clone();
		this.y2=y2.clone();
		n=x1.length;
	}
}

class Scanner{
	BufferedReader br;
	StringTokenizer st;

	Scanner(InputStream in){
		br=new BufferedReader(new InputStreamReader(in));
		eat("");
	}

	void eat(String s){
		st=new StringTokenizer(s);
	}

	String nextLine(){
		try{
			return br.readLine();
		}catch(IOException e){
			throw new IOError(e);
		}
	}

	boolean hasNext(){
		while(!st.hasMoreTokens()){
			String s=nextLine();
			if(s==null)
				return false;
			eat(s);
		}
		return true;
	}

	String next(){
		hasNext();
		return st.nextToken();
	}

	int nextInt(){
		return Integer.parseInt(next());
	}
}