チェスボード上の#575(DIV。3)E.接続されたコンポーネントのラウンドCodeforces(思考、コンフィギュレーション)

チェスボード上の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';
        }
    }
}

おすすめ

転載: www.cnblogs.com/qieqiemin/p/11247876.html