• Helvetic Coding Contest 2016 online mirror B1


    Description

    The zombies are gathering in their secret lair! Heidi will strike hard to destroy them once and for all. But there is a little problem... Before she can strike, she needs to know where the lair is. And the intel she has is not very good.

    Heidi knows that the lair can be represented as a rectangle on a lattice, with sides parallel to the axes. Each vertex of the polygon occupies an integer point on the lattice. For each cell of the lattice, Heidi can check the level of Zombie Contamination. This level is an integer between 0and 4, equal to the number of corners of the cell that are inside or on the border of the rectangle.

    As a test, Heidi wants to check that her Zombie Contamination level checker works. Given the output of the checker, Heidi wants to know whether it could

    have been produced by a single non-zero area rectangular-shaped lair (with axis-parallel sides).

    Input

    The first line of each test case contains one integer N, the size of the lattice grid (5 ≤ N ≤ 50). The next N lines each contain N characters, describing the level of Zombie Contamination of each cell in the lattice. Every character of every line is a digit between 0 and 4.

    Cells are given in the same order as they are shown in the picture above: rows go in the decreasing value of y coordinate, and in one row cells go in the order of increasing x coordinate. This means that the first row corresponds to cells with coordinates (1, N), ..., (N, N) and the last row corresponds to cells with coordinates (1, 1), ..., (N, 1).

    Output

    The first line of the output should contain Yes if there exists a single non-zero area rectangular lair with corners on the grid for which checking the levels of Zombie Contamination gives the results given in the input, and No otherwise.

    Example
    input
    6
    000000
    000000
    012100
    024200
    012100
    000000
    output
    Yes
    Note

    The lair, if it exists, has to be rectangular (that is, have corners at some grid points with coordinates (x1, y1), (x1, y2), (x2, y1), (x2, y2)), has a non-zero area and be contained inside of the grid (that is, 0 ≤ x1 < x2 ≤ N0 ≤ y1 < y2 ≤ N), and result in the levels of Zombie Contamination as reported in the input.

     1,2,3,4的意思是有几个点和内部接触,比如1只有一个点和4接触,2有两个点和4接触,4就在里面就是4个,就是没有3.。

    #include<bits/stdc++.h>
    using namespace std;
    int main()
    {
        int n;
        string a[1000];
        int Mx=-1000,My=-1000,mx=1000,my=1000;
        cin>>n;
        for(int i=0;i<n;i++)
        {
            cin>>a[i];
        }
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<n;j++)
            {
                if(a[i][j]!='0')
                {
                    Mx=max(Mx,i);
                    mx=min(mx,i);
                    My=max(My,j);
                    my=min(my,j);
                }
            }
        }
        if(a[Mx][my]!='1'||a[mx][my]!='1'||a[Mx][My]!='1'||a[mx][My]!='1')
        {
            puts("No");
            return 0;
        }
        else
        {
            for(int j=my+1;j<=My-1;j++)
            {
              //  cout<<a[mx][j];
                if(a[mx][j]!='2')
                {
                    puts("No");
                    return 0;
                }
            }
            for(int j=my+1;j<=My-1;j++)
            {
             //   cout<<a[mx][j];
                if(a[Mx][j]!='2')
                {
                    puts("No");
                    return 0;
                }
            }
            for(int i=mx+1;i<=Mx-1;i++)
            {
              //  cout<<a[i][my];
                if(a[i][my]!='2')
                {
                    puts("No");
                    return 0;
                }
            }
            for(int i=mx+1;i<=Mx-1;i++)
            {
              //  cout<<a[i][My];
                if(a[i][My]!='2')
                {
                    puts("No");
                    return 0;
                }
            }
            for(int i=mx+1;i<=Mx-1;i++)
            {
                for(int j=my+1;j<=My-1;j++)
                {
                    if(a[i][j]!='4')
                    {
                        puts("No");
                        return 0;
                    }
                }
            }
        }
        puts("Yes");
        return 0;
    }
    

      

  • 相关阅读:
    h5页面 禁止缩放
    Mac 建立自己的服务器,支持PHP
    socket(孔、插座 --> 套接字) Socket通信 -- 了解
    核心动画
    popoverPresentationController UIPopoverController 使用方法详解(气泡控制器)
    plist中的中文数据
    Attempt to present <vc> on <vc> which is already presenting <vc>/(null)
    Xcode 8 : iOS xib is missing from working copy、iOS misssing file
    Xcode 中的黄色文件夹/蓝色文件夹
    iOS 容器 addChildViewController
  • 原文地址:https://www.cnblogs.com/yinghualuowu/p/5660642.html
Copyright © 2020-2023  润新知