Pagini recente » Cod sursa (job #3343907) | Cod sursa (job #3317355) | Cod sursa (job #3350826) | Cod sursa (job #3328229) | Cod sursa (job #3347963)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("matrix.in");
ofstream fout("matrix.out");
int n,m,a[1005][1005],i,j,dp[1005][1005],nrap[26],fr[1005][1005],k,nrsol,nr;
char c;
int main()
{
fin>>n>>m;
for(i=1; i<=n; i++)
for(j=1; j<=n; j++)
{
fin>>c;
a[i][j]=c-'a';
}
for(i=1; i<=m; i++)
for(j=1; j<=m; j++)
{
fin>>c;
nrap[c-'a']++;
}
for(k=0; k<26; k++)
{
fr[1][1]=0;
for(i=1; i<=n; i++)
for(j=1; j<=n; j++)
{
fr[i][j]=fr[i-1][j]+fr[i][j-1]-fr[i-1][j-1];
if(a[i][j]==k) fr[i][j]++;
}
for(i=m; i<=n; i++)
for(j=m; j<=n; j++)
{
nr=fr[i][j]-fr[i][j-m]-fr[i-m][j]+fr[i-m][j-m];
if(nr==nrap[k])
dp[i][j]++;
}
}
for(i=1; i<=n; i++)
for(j=1; j<=n; j++)
if(dp[i][j]==26) nrsol++;
fout<<nrsol;
return 0;
}