Cod sursa(job #3347963)

Utilizator iustin.dumiDumitrescu Iustin iustin.dumi Data 19 martie 2026 08:38:52
Problema Matrix Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.06 kb
#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;
}