#include using namespace std; typedef long long ll; int c[2001][2001][26]; signed main(){ //cout << setprecision(16) ; ios::sync_with_stdio(false); cin.tie(0); int h,w,n; cin>>h>>w>>n; string s[h]; for(int i=0;i>s[i]; for(int j=0;j1){ mid=(up+low)/2; //上半分か下半分の条件を求める cnt = 0; for(int k=0;k<26;k++){ if(c[i][j][k] - c[i-mid][j][k] - c[i][j-mid][k] + c[i-mid][j-mid][k]>0) cnt++; } //上半分の時 if(cnt<=n){ low=mid; } //下半分の時 else{ up=mid; } } //lowが答え upper = low; low = -1, up = min(i,j)+1; while(up-low>1){ mid=(up+low)/2; //上半分か下半分の条件を求める cnt = 0; for(int k=0;k<26;k++){ if(c[i][j][k] - c[i-mid][j][k] - c[i][j-mid][k] + c[i-mid][j-mid][k]>0) cnt++; } //上半分の時 if(cnt