チェスボード上のE.接続されたコンポーネントの
テスト2秒のあたりの制限時間
test256メガバイトあたりのメモリ制限
入力inputstandard
出力outputstandard
あなたは二つの整数bとWを与えられています。あなたは、左上のセルとの大きさのチェス盤109×109持っている(1; 1)、セル(1; 1)は白く塗られています。
あなたの仕事はまさにB黒セルと正確ワット白の細胞が含まれています。このチェス盤に接続されているコンポーネントを見つけることです。(X-1、Y)、(X + 1、Y)、(X、Y-1、:それらはすなわちセル(x、y)の最大4接続されたセルがあるため(側を共有する場合、2個のセルが接続と呼ばれ)、(X、Y + 1))。このセットからセルC1、C2の各ペアについて、セルC1、C2、...の配列が存在する場合、細胞のセットは、連結成分と呼ばれるCKようC1 = C1、CK = C2、からすべてのCI K 1は、CIおよびCI + 1のセルが接続されて、細胞のこのセットに属するすべてのi∈[1、K-1]のためのものです。
もちろん、そのようなコンポーネントを見つけることができないことができます。この場合の印刷には「NO」。そうでない場合は、印刷「YES」との任意の適切な連結成分。
あなたは、Qの独立したクエリに応答する必要があります。
入力
クエリの数-入力の最初の行は1つの整数Q(1≤q≤105)を含みます。そして、q個のクエリが続きます。
必要な黒セルの数と必要な白血球の数 - クエリの唯一のラインは、二つの整数、BおよびW(1≤b、w≤105)を含みます。
細胞の数の和が2⋅105(ΣW+Σb≤2⋅105)を超えないことが保証されています。
出力
各クエリに対して、それに対する回答を印刷します。
最初の行に、それは必要なコンポーネントを見つけることは不可能である場合は、印刷「NO」。
それ以外の場合は、最初の行に印刷「YES」。次のB + Wラインに任意の順序でコンポーネントのセルの座標を印刷します。まさにB黒セルとあなたの答えでワット白の細胞があるはずです。印刷されたコンポーネントが接続されるべきです。
いくつかの答えがある場合は、いずれかを印刷することができます。回答のすべての座標は、範囲[; 109 1]であるべきです。
例えば
inputCopy
3
1 1
1 4
2 5
outputCopy
YES
2 2
1 2
YES
2 3
1 3
3 3
2 2
2 4
YES
2 3
2 4
2 5
1 3
1 5
3 3
3 5
質問の意味:
あなたがブロックユニコムを構築することができ、あなたは* 1E9 1E9を逆に与えるために、中国聯通黒ブロック数は、Bは、W白として、ある
アイデア:
ユニコム直接横構築ブロックは、明らかにデータ範囲を満たしています。
別々のマルチ議論の数よりも多くのために黒または白の数、
詳細コードを参照してください。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define rt return
#define dll(x) scanf("%I64d",&x)
#define xll(x) printf("%I64d\n",x)
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define chu(x) cout<<"["<<#x<<" "<<(x)<<"]"<<endl
using namespace std;
typedef long long ll;
ll gcd(ll a, ll b) {return b ? gcd(b, a % b) : a;}
ll lcm(ll a, ll b) {return a / gcd(a, b) * b;}
ll powmod(ll a, ll b, ll MOD) {ll ans = 1; while (b) {if (b % 2)ans = ans * a % MOD; a = a * a % MOD; b /= 2;} return ans;}
inline void getInt(int* p);
const int maxn = 1000010;
const int inf = 0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/
int main()
{
//freopen("D:\\common_text\\code_stream\\in.txt","r",stdin);
// freopen("D:\\common_text\\code_stream\\out.txt","w",stdout);
int q;
gg(q);
while (q--)
{
int b, w;
gg(b); gg(w);
if (b < w)
{
int m = b * 3 + 1;
if (w <= m)
{
printf("YES\n");
cout<<2<<" "<<2<<endl;
w--;
int x=3;
int y=2;
while(1)
{
cout<<y<<" "<<x<<endl;
if(w>b)
{
cout<<y-1<<" "<<x<<endl;
w--;
}
if(w>b)
{
cout<<y+1<<" "<<x<<endl;
w--;
}
if(w)
{
cout<<y<<" "<<x+1<<endl;
w--;
}
b--;
if(!b&&!w)
{
break;
}
x+=2;
}
} else
{
printf("NO\n");
}
} else
{
int m = w * 3 + 1;
if (b <= m)
{
printf("YES\n");
cout<<2<<" "<<3<<endl;
b--;
int x=4;
int y=2;
while(1)
{
cout<<y<<" "<<x<<endl;
if(b>w)
{
cout<<y-1<<" "<<x<<endl;
b--;
}
if(b>w)
{
cout<<y+1<<" "<<x<<endl;
b--;
}
if(b)
{
cout<<y<<" "<<x+1<<endl;
b--;
}
w--;
if(!b&&!w)
{
break;
}
x+=2;
}
} else
{
printf("NO\n");
}
}
cout<<endl;
}
return 0;
}
inline void getInt(int* p) {
char ch;
do {
ch = getchar();
} while (ch == ' ' || ch == '\n');
if (ch == '-') {
*p = -(getchar() - '0');
while ((ch = getchar()) >= '0' && ch <= '9') {
*p = *p * 10 - ch + '0';
}
}
else {
*p = ch - '0';
while ((ch = getchar()) >= '0' && ch <= '9') {
*p = *p * 10 + ch - '0';
}
}
}