2020ICPC·小米 网络选拔赛第一场 J-Matrix Subtraction(二维差分)

题目大意:给nxm和axb的矩阵,每次从nxm矩阵中选择axb子矩阵使每个元素-1,问nxm矩阵能否所有元素为0.

题解:网上找的官方题解

 

 

传送门

代码:

队友写的...应该不是差分 正解明天补

复制代码
#include<iostream>
#include<string>
using namespace std;
int a1[1010][1010];
int main()
{
    int t;
    cin>>t;
    int n,m,a,b;
    int i,i1,i2,i3;
    int c;
    bool k=0,k1=0;
    while(t--)
    {
        cin>>n>>m>>a>>b;
        for(i=0;i<n;i++)
        {
            for(i1=0;i1<m;i1++)
            {
                scanf("%d",&a1[i][i1]);
            }
        }
        int n1=n/a-1;
        int m1=m-b+1;
        k=0;
        for(i=0;i<n1;i++)
        {
            for(i1=0;i1<m1;i1++)
            {
                if(a1[i*a][i1]>=0)
                {
                    for(i2=i*a+1;i2<a+i*a;i2++)
                    {
                        if(a1[i2][i1]<a1[i2-1][i1]) 
                        {
                            cout<<"QAQ"<<endl;
                            k=1;
                            break;
                        }
                    }
                    if(k)
                    {
                        break;
                    }
                    for(i2=i*a;i2<a+i*a;i2++)
                    {
                        for(i3=i1+b-1;i3>i1-1;i3--)
                        {
                            a1[i2+a][i3]-=a1[i*a+a-1][i1]-a1[i2][i1];
                        }
                    }
                    for(i2=i*a;i2<a+i*a;i2++)
                    {
                        for(i3=i1+b-1;i3>i1-1;i3--)
                        {
                            a1[i2][i3]-=a1[i2][i1];
                        }
                    }
                }
            }
            if(k)
            {
                break;
            }
        }
        if(k)
        {
            k=0;
            continue;
        }
        for(i1=0;i1<m1;i1++)
        {
            if(a1[i*a][i1]>=0)
            {
                for(i2=i*a+1;i2<i*a+n%a+1;i2++)
                {
                    if(a1[i2][i1]<a1[i2-1][i1]) 
                    {
                        cout<<"QAQ"<<endl;
                        k=1;
                        break;
                    }
                }
                if(k)
                {
                    break;
                } 
                for(;i2<i*a+a;i2++)
                {
                    if(a1[i2][i1]!=a1[i2-1][i1]) 
                    {
                        cout<<"QAQ"<<endl;
                        k=1;
                        break;
                    }
                }
                if(k)
                {
                    break;
                }
                for(i2=i*a;i2<i*a+n%a+1;i2++)
                {
                    for(i3=i1+b-1;i3>i1-1;i3--)
                    {
                        a1[i2+a][i3]-=a1[i*a+a-1][i1]-a1[i2][i1];
//                        cout<<i2+a<<' '<<i3<<' '<<i*a+a-1<<' '<<i1<<' '<<i2<<' '<<i1<<endl;
//                        cout<<a1[i2+a][i3]<<' '<<a1[i*a+a-1][i1]<<' '<<a1[i2][i1]<<endl;
                    }
                }
                for(i2=i*a;i2<a+i*a;i2++)
                {
                    for(i3=i1+b-1;i3>i1-1;i3--)
                    {
                        a1[i2][i3]-=a1[i2][i1];
                    }
                }
            }
        }
        if(k)
        {
            k=0;
            continue;
        }
        for(i=0;i<n;i++)
        {
            for(i1=0;i1<m;i1++)
            {
                if(a1[i][i1])
                {
                    k=1;
                }
//                cout<<a1[i][i1]<<' ';
            }
//            cout<<endl;
        }
        if(k)
        {
            k=0;
            cout<<"QAQ"<<endl;
        }
        else
        {
            cout<<"^_^"<<endl;
        }
    }
} 
View Code
复制代码

 

posted @   ANhour  阅读(284)  评论(0编辑  收藏  举报
编辑推荐:
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
阅读排行:
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· Winform-耗时操作导致界面渲染滞后
· Phi小模型开发教程:C#使用本地模型Phi视觉模型分析图像,实现图片分类、搜索等功能
· 语音处理 开源项目 EchoSharp
· drools 规则引擎和 solon-flow 哪个好?solon-flow 简明教程
点击右上角即可分享
微信分享提示