给定一个N行M列的矩阵,由 0 和 1 组成。任务是找到矩阵中仅包含 1 的子图的周长。单个 1 的周长是 4,因为它可以从所有 4 边覆盖。双11的周长是6。
| 1 | | 1 1 |
例子:
Input : mat[][] =
{
1, 0,
1, 1,
}
Output : 8
Cell (1,0) and (1,1) making a L shape whose perimeter is 8.
Input : mat[][] =
{
0, 1, 0, 0, 0,
1, 1, 1, 0, 0,
1, 0, 0, 0, 0
}
Output : 12
这个想法是遍历矩阵,找到所有的并找到它们在周长中的贡献。如果 1 被全 0 包围,则其最大贡献为 4。贡献减少一,周围是 1。
解决这个问题的算法:
- 遍历整个矩阵并找到值等于 1 的单元格。
- 计算该单元格的封闭边数并将 4 – 封闭边数添加到总周长。
下面是这个方法的实现:
C++
// C++ program to find perimeter of area coverede by
// 1 in 2D matrix consisits of 0's and 1's.
#include
using namespace std;
#define R 3
#define C 5
// Find the number of covered side for mat[i][j].
int numofneighbour(int mat[][C], int i, int j)
{
int count = 0;
// UP
if (i > 0 && mat[i - 1][j])
count++;
// LEFT
if (j > 0 && mat[i][j - 1])
count++;
// DOWN
if (i < R-1 && mat[i + 1][j])
count++;
// RIGHT
if (j < C-1 && mat[i][j + 1])
count++;
return count;
}
// Returns sum of perimeter of shapes formed with 1s
int findperimeter(int mat[R][C])
{
int perimeter = 0;
// Traversing the matrix and finding ones to
// calculate their contribution.
for (int i = 0; i < R; i++)
for (int j = 0; j < C; j++)
if (mat[i][j])
perimeter += (4 - numofneighbour(mat, i ,j));
return perimeter;
}
// Driven Program
int main()
{
int mat[R][C] =
{
0, 1, 0, 0, 0,
1, 1, 1, 0, 0,
1, 0, 0, 0, 0,
};
cout << findperimeter(mat) << endl;
return 0;
}
Java
// Java program to find perimeter of area
// coverede by 1 in 2D matrix consisits
// of 0's and 1's
class GFG {
static final int R = 3;
static final int C = 5;
// Find the number of covered side
// for mat[i][j].
static int numofneighbour(int mat[][],
int i, int j)
{
int count = 0;
// UP
if (i > 0 && mat[i - 1][j] == 1)
count++;
// LEFT
if (j > 0 && mat[i][j - 1] == 1)
count++;
// DOWN
if (i < R - 1 && mat[i + 1][j] == 1)
count++;
// RIGHT
if (j < C - 1 && mat[i][j + 1] == 1)
count++;
return count;
}
// Returns sum of perimeter of shapes
// formed with 1s
static int findperimeter(int mat[][])
{
int perimeter = 0;
// Traversing the matrix and
// finding ones to calculate
// their contribution.
for (int i = 0; i < R; i++)
for (int j = 0; j < C; j++)
if (mat[i][j] == 1)
perimeter += (4 -
numofneighbour(mat, i, j));
return perimeter;
}
// Driver code
public static void main(String[] args)
{
int mat[][] = {{0, 1, 0, 0, 0},
{1, 1, 1, 0, 0},
{1, 0, 0, 0, 0}};
System.out.println(findperimeter(mat));
}
}
// This code is contributed by Anant Agarwal.
Python3
# Python3 program to find perimeter of area
# covered by 1 in 2D matrix consisits of 0's and 1's.
R = 3
C = 5
# Find the number of covered side for mat[i][j].
def numofneighbour(mat, i, j):
count = 0;
# UP
if (i > 0 and mat[i - 1][j]):
count+= 1;
# LEFT
if (j > 0 and mat[i][j - 1]):
count+= 1;
# DOWN
if (i < R-1 and mat[i + 1][j]):
count+= 1
# RIGHT
if (j < C-1 and mat[i][j + 1]):
count+= 1;
return count;
# Returns sum of perimeter of shapes formed with 1s
def findperimeter(mat):
perimeter = 0;
# Traversing the matrix and finding ones to
# calculate their contribution.
for i in range(0, R):
for j in range(0, C):
if (mat[i][j]):
perimeter += (4 - numofneighbour(mat, i, j));
return perimeter;
# Driver Code
mat = [ [0, 1, 0, 0, 0],
[1, 1, 1, 0, 0],
[1, 0, 0, 0, 0] ]
print(findperimeter(mat), end="\n");
# This code is contributed by Akanksha Rai
C#
using System;
// C# program to find perimeter of area
// coverede by 1 in 2D matrix consisits
// of 0's and 1's
public class GFG
{
public const int R = 3;
public const int C = 5;
// Find the number of covered side
// for mat[i][j].
public static int numofneighbour(int[][] mat, int i, int j)
{
int count = 0;
// UP
if (i > 0 && mat[i - 1][j] == 1)
{
count++;
}
// LEFT
if (j > 0 && mat[i][j - 1] == 1)
{
count++;
}
// DOWN
if (i < R - 1 && mat[i + 1][j] == 1)
{
count++;
}
// RIGHT
if (j < C - 1 && mat[i][j + 1] == 1)
{
count++;
}
return count;
}
// Returns sum of perimeter of shapes
// formed with 1s
public static int findperimeter(int[][] mat)
{
int perimeter = 0;
// Traversing the matrix and
// finding ones to calculate
// their contribution.
for (int i = 0; i < R; i++)
{
for (int j = 0; j < C; j++)
{
if (mat[i][j] == 1)
{
perimeter += (4 - numofneighbour(mat, i, j));
}
}
}
return perimeter;
}
// Driver code
public static void Main(string[] args)
{
int[][] mat = new int[][]
{
new int[] {0, 1, 0, 0, 0},
new int[] {1, 1, 1, 0, 0},
new int[] {1, 0, 0, 0, 0}
};
Console.WriteLine(findperimeter(mat));
}
}
// This code is contributed by Shrikant13
PHP
0 && ($mat[$i - 1][$j]))
$count++;
// LEFT
if ($j > 0 && ($mat[$i][$j - 1]))
$count++;
// DOWN
if (($i < $R-1 )&& ($mat[$i + 1][$j]))
$count++;
// RIGHT
if (($j < $C-1) && ($mat[$i][$j + 1]))
$count++;
return $count;
}
// Returns sum of perimeter of shapes
// formed with 1s
function findperimeter($mat)
{
global $R;
global $C;
$perimeter = 0;
// Traversing the matrix and finding ones
// to calculate their contribution.
for ($i = 0; $i < $R; $i++)
for ( $j = 0; $j < $C; $j++)
if ($mat[$i][$j])
$perimeter += (4 -
numofneighbour($mat, $i, $j));
return $perimeter;
}
// Driver Code
$mat = array(array(0, 1, 0, 0, 0),
array(1, 1, 1, 0, 0),
array(1, 0, 0, 0, 0));
echo findperimeter($mat), "\n";
// This code is contributed by Sach_Code
?>
Javascript
输出:
12
时间复杂度: O(RC)。
如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程和学生竞争性编程现场课程。