#include #include int l = 0, m, n, nrc = 0; int b[400][400]; char a[400][401]; char c[26]; void Lee(char, int, int); void Init(); void GetCrops(); int main() { int type, i, j, is, js, k, cs; unsigned long int max = 0; char a2[2]; Init(); scanf("%d%d%d", &type, &m, &n); gets(a2); for (i = 0; i < m; i++) gets(a[i]); // for (i = 0; i < m; i++) // puts(a[i]); if (type == 1) { Init(); for (i = 0; i < m; i++) for (j = 0; j < n; j++) { if (b[i][j] == 0) Lee(a[i][j], i, j); if (max < l) max = l; l = 0; } printf("%lu", max); } else if (type == 2) { GetCrops(); for (i = 0; i < m; i++) for (j = 0; j < n; j++) { for (k = 0; k < nrc; k++) { Init(); Lee(c[k],i,j); if ((l > max) || ((l == max) && (cs > c[k]))) { is = i; js = j; max = l; cs = c[k]; } } } printf("%d %d\n%c", is+1, js+1, cs); } return 0; } void Lee(char c, int i, int j) { l += 1; b[i][j] = 1; //Right if ((j + 1) < n) if ((a[i][j+1] == c) && (b[i][j+1] == 0)) Lee(c, i, j+1); //Left if ((j-1) >= 0) if ((a[i][j-1] == c) && (b[i][j-1] == 0)) Lee(c, i, j-1); //Up if ((i-1) >= 0) if ((a[i-1][j] == c) && (b[i-1][j] == 0)) Lee(c, i-1, j); //Down if ((i+1) < m) if ((a[i+1][j] == c) && (b[i+1][j] == 0)) Lee(c, i+1,j); } void Init() { int i, j; l = 0; for (i = 0; i < 400; i++) for(j = 0; j < 400; j++) b[i][j] = 0; } void GetCrops() { int found, i, j, k; for (i = 0; i < m; i++) for (j = 0; j < n; j++) { found = 0; for (k = 0; k < nrc; k++) if (a[i][j] == c[k]) found = 1; if (found == 0) { nrc += 1; c[nrc-1] = a[i][j]; } } }