题意:给你三块玻璃,看能否拼成一整块正方形玻璃?

一共有四种情况,讨论即可

#include <iostream>
#include<bits/stdc++.h>
using namespace std;
struct node
{
    int x,y;
    bool operator <(const node& p)
    {
        if(x==p.x)
        {
            return y>p.y;
        }
        else return x>p.x;
    }
};
int main()
{
    node a[10];
    int sum =0;
    for(int i=0;i<=2;i++)
    {
        cin>>a[i].x>>a[i].y;
        if(a[i].x<a[i].y)
            swap(a[i].x,a[i].y);
         sum+=a[i].x*a[i].y;
    }
    sort(a,a+3);
    int r = (int )sqrt(sum);
    int f =0;
    if(r*r==sum)
    {
         if(a[0].x==r)
         {
             int p = r-a[0].y;
             if(a[1].x==a[2].x&&a[1].x==r&&p==a[1].y+a[2].y)f =1;
             if(a[1].x==a[2].x&&a[1].x==p&&a[1].y+a[2].y==r)f =1;
             if(a[1].y==a[2].y&&a[1].y==p&&a[1].x+a[2].x==r)f =1;
             if(a[1].x+a[2].y==r&&a[1].y==a[2].x&&a[1].y==p)f= 1;
         }

    }
    if(f)printf("YES\n");
    else printf("NO\n");

    return 0;
}