Codeforces Round #322 D Three Logos

题意:给你6个数x1,y1,x2,y2,x3,y3、 这6个数分别为一个广告牌的长和宽、问你这3个广告牌是否可以组成一个n*n的正方形、 第一个广告牌的字母为A,第二个为B第三个为C

输出这个正方形,如果有多组,随便输出其中一组便可、广告牌只能用一次,也可以旋转、

思路:可以想到,如果三个广告牌可以组成正方形的话,那么正方形N的边长一定为6个数中的最大值、那么既然知道了正方形的大小,便可以将边长等于这个正方形的一个广告牌先放入,剩下两个广告牌组合便可、 我的思路不是特别好,虽然能AC不过代码特别长、

AC代码:

#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=110;
int map[maxn][maxn];
int n;
int x1,y1;
int x2,y2;
int x3,y3;
int xx;
int falg;
void Init()
{
    xx=0;
    if(x1<y1)
        swap(x1,y1);
    if(x2<y2)
        swap(x2,y2);
    if(x3<y3)
        swap(x3,y3);
    xx=max(x1,xx);
    xx=max(x2,xx);
    xx=max(x3,xx);
    if(xx==x1)
        falg=1;
    else if(xx==x2)
        falg=2;
    else if(xx==x3)
        falg=3;
}
int main()
{
    while(scanf("%d %d %d %d %d %d",&x1,&y1,&x2,&y2,&x3,&y3)!=EOF){
        Init();
        if(x1==x2&&x2==x3&&y1+y2+y3==xx){
            printf("%d\n",xx);
            for(int i=0;i<y1;i++){
                for(int j=0;j<x1;j++)
                    printf("A");
                printf("\n");
            }
            for(int i=0;i<y2;i++){
                for(int j=0;j<x2;j++)
                    printf("B");
                printf("\n");
            }
            for(int i=0;i<y3;i++){
                for(int j=0;j<x3;j++)
                    printf("C");
                printf("\n");
            }
            continue;
        }
        if(falg==1){
            if(x2==x3&&x2+y1==xx&&y2+y3==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                printf("\n");
                }
                for(int i=0;i<x2;i++){
                    for(int j=0;j<y2;j++)
                        printf("B");
                    for(int j=0;j<y3;j++)
                        printf("C");
                    printf("\n");
                }
                continue;
            }
            else if(y2==x3&&y2+y1==xx&&x2+y3==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                printf("\n");
                }
                for(int i=0;i<y2;i++){
                    for(int j=0;j<x2;j++)
                        printf("B");
                    for(int j=0;j<y3;j++)
                        printf("C");
                    printf("\n");
                }
                continue;
            }
            else if(x2==y3&&x2+y1==xx&&y2+x3==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                printf("\n");
                }
                for(int i=0;i<x2;i++){
                    for(int j=0;j<y2;j++)
                        printf("B");
                    for(int j=0;j<x3;j++)
                        printf("C");
                    printf("\n");
                }
                continue;
            }
            else if(y2==y3&&y2+y1==xx&&x2+x3==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                printf("\n");
                }
                for(int i=0;i<y2;i++){
                    for(int j=0;j<x2;j++)
                        printf("B");
                    for(int j=0;j<x3;j++)
                        printf("C");
                    printf("\n");
                }
                continue;
            }
        }
        else if(falg==2){
            if(x1==x3&&x1+y2==xx&&y1+y3==xx){
                printf("%d\n",xx);
                for(int i=0;i<x1;i++){
                    for(int j=0;j<y1;j++)
                        printf("A");
                    for(int j=0;j<y3;j++)
                        printf("C");
                    printf("\n");
                }
                for(int i=0;i<y2;i++){
                    for(int j=0;j<x2;j++)
                        printf("B");
                printf("\n");

                }
                continue;
            }
            else if(y1==x3&&y1+y2==xx&&x1+y3==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                    for(int j=0;j<y3;j++)
                        printf("C");
                    printf("\n");
                }
                for(int i=0;i<y2;i++){
                    for(int j=0;j<x2;j++)
                        printf("B");
                printf("\n");
                }
                continue;
            }
            else if(x1==y3&&x1+y2==xx&&y1+x3==xx){
                printf("%d\n",xx);
                for(int i=0;i<x1;i++){
                    for(int j=0;j<y1;j++)
                        printf("A");
                    for(int j=0;j<x3;j++)
                        printf("C");
                    printf("\n");
                }
                for(int i=0;i<y2;i++){
                    for(int j=0;j<x2;j++)
                        printf("B");
                printf("\n");
                }
                continue;
            }
            else if(y1==y3&&y1+y2==xx&&x1+x3==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                    for(int j=0;j<x3;j++)
                        printf("C");
                    printf("\n");
                }
                for(int i=0;i<y2;i++){
                    for(int j=0;j<x2;j++)
                        printf("B");
                printf("\n");
                }
                continue;
            }
        }
        else if(falg==3){

            if(x1==x2&&x1+y3==xx&&y1+y2==xx){
                printf("%d\n",xx);
                for(int i=0;i<x1;i++){
                    for(int j=0;j<y1;j++)
                        printf("A");
                    for(int j=0;j<y2;j++)
                        printf("B");
                    printf("\n");
                }
                for(int i=0;i<y3;i++){
                    for(int j=0;j<x3;j++)
                        printf("C");
                printf("\n");
                }
                continue;
            }
            else if(y1==x2&&y1+y3==xx&&x1+y2==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                    for(int j=0;j<y2;j++)
                        printf("B");
                    printf("\n");
                }
                for(int i=0;i<y3;i++){
                    for(int j=0;j<x3;j++)
                        printf("C");
                printf("\n");
                }
                continue;
            }
            else if(x1==y2&&x1+y3==xx&&y1+x2==xx){
                printf("%d\n",xx);
                for(int i=0;i<x1;i++){
                    for(int j=0;j<y1;j++)
                        printf("A");
                    for(int j=0;j<x2;j++)
                        printf("B");
                    printf("\n");
                }
                for(int i=0;i<y3;i++){
                    for(int j=0;j<x3;j++)
                        printf("C");
                printf("\n");
                }
                continue;
            }
            else if(y1==y2&&y1+y3==xx&&x1+x2==xx){
                printf("%d\n",xx);
                for(int i=0;i<y1;i++){
                    for(int j=0;j<x1;j++)
                        printf("A");
                    for(int j=0;j<x2;j++)
                        printf("B");
                    printf("\n");
                }
                for(int i=0;i<y3;i++){
                    for(int j=0;j<x3;j++)
                        printf("C");
                printf("\n");
                }
                continue;
            }
        }
        printf("-1\n");
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值