ในปัญหานี้ เราได้รับ NxN binary matrix bin[][] งานของเราคือการหาขนาดของ '+' ที่ใหญ่ที่สุดที่สร้างขึ้นโดยทุกอันในเมทริกซ์ไบนารี
มาดูตัวอย่างเพื่อทำความเข้าใจปัญหากัน
อินพุต
0 1 1 1 1 1 0 1 0
ผลลัพธ์
5
แนวทางการแก้ปัญหา
วิธีแก้ปัญหาอย่างง่ายคือการหา '+' ที่ใหญ่ที่สุดที่เราต้องหาจำนวนสูงสุดของ 1 ในทิศทางเดียวสำหรับจุดในเมทริกซ์ซึ่งต้องเหมือนกันในทั้งสี่ทิศทางสำหรับ 1 ที่กำหนด สำหรับสิ่งนี้ เราจะสร้างเมทริกซ์หนึ่งเมทริกซ์สำหรับแต่ละด้านของจุดนั่นคือ 4 แต่ละอันจะเก็บจำนวน 1 ที่ต่อเนื่องกันสำหรับองค์ประกอบที่กำหนด สำหรับค่าดัชนีทั้งหมด เราจะหาค่าสูงสุดซึ่งเป็นค่าต่ำสุดของค่าที่ต่อเนื่องกันทั้งสี่ทิศทาง
โปรแกรมเพื่อแสดงการทำงานของโซลูชันของเรา
ตัวอย่าง
#include <iostream>
using namespace std;
#define N 7
int findLargestPlusSize(int mat[N][N]) {
int conOneLeft[N][N], conOneRight[N][N], conOneTop[N][N], conOneBottom[N][N];
for (int i = 0; i < N; i++) {
conOneTop[0][i] = mat[0][i];
conOneBottom[N - 1][i] = mat[N - 1][i];
conOneLeft[i][0] = mat[i][0];
conOneRight[i][N - 1] = mat[i][N - 1];
}
for (int i = 0; i < N; i++) {
for (int j = 1; j < N; j++) {
if (mat[i][j] == 1)
conOneLeft[i][j] = conOneLeft[i][j - 1] + 1;
else
conOneLeft[i][j] = 0;
if (mat[j][i] == 1)
conOneTop[j][i] = conOneTop[j - 1][i] + 1;
else
conOneTop[j][i] = 0;
j = N - 1 - j;
if (mat[j][i] == 1)
conOneBottom[j][i] = conOneBottom[j + 1][i] + 1;
else
conOneBottom[j][i] = 0;
if (mat[i][j] == 1)
conOneRight[i][j] = conOneRight[i][j + 1] + 1;
else
conOneRight[i][j] = 0;
j = N - 1 - j;
}
}
int maxConOne = 0;
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++){
int ConOnes = min(min(conOneTop[i][j],
conOneBottom[i][j]), min(conOneLeft[i][j], conOneRight[i][j]));
if(ConOnes > maxConOne)
maxConOne = ConOnes;
}
}
if (maxConOne)
return (4 * (maxConOne - 1) + 1);
return 0;
}
int main() {
int mat[N][N] = {
{ 1, 0, 1, 1, 1, 1, 0 },
{ 1, 0, 1, 0, 1, 1, 1 },
{ 1, 1, 1, 0, 1, 1, 0 },
{ 0, 0, 0, 0, 1, 0, 0 },
{ 1, 0, 1, 1, 1, 1, 1 },
{ 1, 1, 1, 0, 1, 1, 1 },
{ 1, 0, 0, 0, 1, 0, 0 },
};
cout<<"The size of the largest plus formed by ones is "<<findLargestPlusSize(mat);
return 0;
} ผลลัพธ์
The size of the largest plus formed by ones is 9