给定两个(正方形)矩阵,判断第二个是否为第一个的子矩阵。
#include<bits/stdc++.h>
using namespace std;
int main()
{
char a[51][51], b[51][51];
int n,m;
cin >> n >> m;
for (int i=0; i<n; i++)
for (int j=0; j<n; j++)
cin >> a[i][j];
for (int i=0; i<m; i++)
for (int j=0; j<m; j++)
cin >> b[i][j];
bool ok;
for (int i=0; i<n-m+1; i++)
{
for (int j=0; j<n-m+1; j++)
{
ok = true;
for (int k=0; k<m; k++)
{
for (int h=0; h<m; h++)
{
if (b[k][h] != a[k+i][h+j])
{ok = false; goto L;}
}
} if (ok) goto LL;
L:;
}
}
LL : ok ? cout << "Yes" : cout << "No";
return 0;
}
https://atcoder.jp/contests/abc054/tasks/abc054_b