CF11C.How Many Squares?

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

You are given a 0-1 rectangular matrix. What is the number of squares in it? A square is a solid square frame (border) with linewidth equal to 1. A square should be at least 2×22×2 . We are only interested in two types of squares:

  1. squares with each side parallel to a side of the matrix;
  2. squares with each side parallel to a diagonal of the matrix.

For example the following matrix contains only one square of the first type:

0000000
0111100 
0100100
0100100 
0111100

The following matrix contains only one square of the second type:

0000000
0010000
0101000
0010000
0000000

Regardless of type, a square must contain at least one 1 and can't touch (by side or corner) any foreign 1. Of course, the lengths of the sides of each square should be equal.

How many squares are in the given matrix?

输入格式

The first line contains integer tt ( 1<=t<=100001<=t<=10000 ), where tt is the number of test cases in the input. Then test cases follow. Each case starts with a line containing integers nn and mm ( 2<=n,m<=2502<=n,m<=250 ), where nn is the number of rows and mm is the number of columns. The following nn lines contain mm characters each (0 or 1).

The total number of characters in all test cases doesn't exceed 10610^{6} for any input file.

输出格式

You should output exactly tt lines, with the answer to the ii -th test case on the ii -th line.

输入输出样例

  • 输入#1

    2
    8 8
    00010001
    00101000
    01000100
    10000010
    01000100
    00101000
    11010011
    11000011
    10 10
    1111111000
    1000001000
    1011001000
    1011001010
    1000001101
    1001001010
    1010101000
    1001001000
    1000001000
    1111111000
    

    输出#1

    1
    2
    
  • 输入#2

    1
    12 11
    11111111111
    10000000001
    10111111101
    10100000101
    10101100101
    10101100101
    10100000101
    10100000101
    10111111101
    10000000001
    11111111111
    00000000000
    

    输出#2

    3
    
首页