#include using namespace std; using ll = long long; const ll INF = 1LL << 60; #define all(a) begin(a), end(a) #define sz(a) ssize(a) template bool chmin(T& a, U b) { return a > b ? a = b, 1 : 0; } template bool chmax(T& a, U b) { return a < b ? a = b, 1 : 0; } using pll = pair; using vpll = vector; using vll = vector; using vvll = vector; #define _O(_1, _2, _3, n, ...) n #define _r1(i, n) for(ll i = 0; i < (ll)(n); i++) #define _r2(i, l, r) for(ll i = (ll)(l); i < (ll)(r); i++) #define rep(...) _O(__VA_ARGS__, _r2, _r1)(__VA_ARGS__) #define _rr1(i, n) for(ll i = (ll)(n) - 1; i >= 0; i--) #define _rr2(i, l, r) for(ll i = (ll)(r) - 1; i >= (ll)(l); i--) #define rrep(...) _O(__VA_ARGS__, _rr2, _rr1)(__VA_ARGS__) template ostream& operator<<(ostream& o, const vector& v) { ll i = 0; for(auto& x : v) o << (i++ ? " " : "") << x; return o; } template void out(const H& h, const T&... t) { cout << h; ((cout << " " << t), ...); cout << endl; } int main(){ ll n; cin >> n; vector s(n); rep(i,n) cin >> s[i]; vll a(n,0), b(2*n,0); rep(i,n) rep(j,n*2) a[i] += (s[i][j] == '#'), b[j] += (s[i][j] == '#'); rep(i,n-1) a[i+1] += a[i]; rep(i,2*n-1) b[i+1] += b[i]; ll ans = 0; rep(i,n-1) ans += abs(n*(i+1)-a[i]); rep(i,n) ans += b[i]; rep(i,n) ans += (b[i+n]-n*(i+1)); out(ans); }