Cod sursa(job #2527179)

Utilizator BlueLuca888Girbovan Robert Luca BlueLuca888 Data 19 ianuarie 2020 19:13:00
Problema Matrix Scor 70
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.99 kb
#include <iostream>
#include <fstream>

using namespace std;

ifstream fin  ("matrix.in");
ofstream fout ("matrix.out");

char lit, car;
int n, m, sol;
int s[1005][1005][28], virus[130];
bool ok;


int main (){
      fin>>n>>m;
      for(int i=1; i<=n; i++)
            for(int j=1; j<=n; j++){
                  fin>>car;
                  for(char c='a'; c<='z'; c++)
                        s[i][j][c-'a']=s[i-1][j][c-'a'] + s[i][j-1][c-'a'] - s[i-1][j-1][c-'a'];

                  s[i][j][car-'a']++;
            }
      for(int i=1; i<=m; i++)
            for(int j=1; j<=m; j++)
                  fin>>lit, virus[lit-'a']++;


      for(int i=m; i<=n; i++)
            for(int j=m; j<=n; j++){
                  ok=1;
                  for(char c='a'; c<='z'; c++)
            if(s[i][j][c-'a']-s[i-m][j][c-'a']-s[i][j-m][c-'a']+s[i-m][j-m][c-'a']!=virus[c-'a'])
                  ok=0;
                  sol+=ok;
            }

      fout<<sol;
      return 0;
}