Cod sursa(job #2355931)

Utilizator mirceaisherebina mircea mirceaishere Data 26 februarie 2019 13:30:08
Problema Matrix Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.16 kb
#include <fstream>
using namespace std;
ifstream fin("matrix.in");
ofstream fout("matrix.out");

int i, j, n, m, f[100], x, d[1010][1010], sol;
char v[1010][1010], ok[1010][1010], c;

int main(){
    fin>>n>>m;
    for(i=1; i<=n; i++){
        for(j=1; j<=n; j++){
            fin>>v[i][j];
            ok[i][j]=1;
        }
    }
    for(i=1; i<=m; i++){
        for(j=1; j<=m; j++){
            fin>>c;
            x=c-'a'+1;
            f[x]++;
        }
    }
    for(c='a'; c<='z'; c++){
        for(i=1; i<=n; i++){
            for(j=1; j<=n; j++){
                d[i][j]=d[i-1][j]+d[i][j-1]-d[i-1][j-1];
                if(v[i][j]==c){
                    d[i][j]++;
                }
            }
        }
        for(i=m; i<=n; i++){
            for(j=m; j<=n; j++){
                int nr=d[i][j]-d[i][j-m]-d[i-m][j]+d[i-m][j-m];
                x=c-'a'+1;
                if(nr!=f[x]){
                    ok[i][j]=0;
                }
            }
        }
    }
    for(i=m; i<=n; i++){
        for(j=m; j<=n; j++){
            if(ok[i][j]==1){
                sol++;
            }
        }
    }
    fout<<sol;
}