#include <cassert>
#include <cctype>
#include <cerrno>
#include <cfloat>
#include <ciso646>
#include <climits>
#include <clocale>
#include <cmath>
#include <csetjmp>
#include <csignal>
#include <cstdarg>
#include <cstddef>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <ccomplex>
#include <cfenv>
#include <cinttypes>
#include <cstdbool>
#include <cstdint>
#include <ctgmath>
#include <cwchar>
#include <cwctype>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <exception>
#include <fstream>
#include <functional>
#include <iomanip>
#include <ios>
#include <iosfwd>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <locale>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <stdexcept>
#include <streambuf>
#include <string>
#include <typeinfo>
#include <utility>
#include <valarray>
#include <vector>
#include <array>
#include <atomic>
#include <chrono>
#include <condition_variable>
#include <forward_list>
#include <future>
#include <initializer_list>
#include <mutex>
#include <random>
#include <ratio>
#include <regex>
#include <scoped_allocator>
#include <system_error>
#include <thread>
#include <tuple>
#include <typeindex>
#include <type_traits>
#include <unordered_map>
#include <unordered_set>
using namespace std;
#define pb push_back
#define eb emplace_back
#define mp make_pair
#define pii pair<int,int>
#define pll pair<long long , long long>
#define vi vector<int>
#define vpii vector<pii>
#define SZ(x) ((int)(x.size()))
#define fi first
#define se second
#define IN(x,y) ((y).find((x))!=(y).end())
#define ALL(t) t.begin(),t.end()
#define FOREACH(i,t) for (typeof(t.begin()) i=t.begin(); i!=t.end(); i++)
#define REP(i,a,b) for(int (i)=(a);(i)<=(b);++i)
#define REPD(i,a,b) for(int (i)=(a); (i)>=(b);--i)
#define FOR(i, n) for (int (i) = 0; (i) < (n); ++(i))
#define dem(x) __builtin_popcount(x)
#define Mask(x) (1LL << (x))
#define BIT(x, i) ((x) >> (i) & 1)
#define ln '\n'
#define io_faster ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
///mt19937 rnd(time(0));
const int INF = 1e9 , mod = 1e9 + 7;
template <class T1, class T2>
inline T1 mul(T1& x, const T2 &k){ return x = (1LL * x * k) % mod; }
template <class T1 , class T2>
inline T1 pw(T1 x, T2 k){T1 res = 1; for (; k ; k >>= 1){ if (k & 1) mul(res, x); mul(x, x); } return res;}
template <class T>
inline bool minimize(T &x, const T &y){ if (x > y){x = y; return 1;} return 0; }
template <class T>
inline bool maximize(T &x, const T &y){ if (x < y){x = y; return 1;} return 0; }
template <class T>
inline void add(T &x , const T &y){ if ((x += y) >= mod) x -= mod; }
template <class T>
inline T product (const T &x , const T &y) { return 1LL * x * y % mod; }
#define PROB "formation"
void file(){
if(fopen(PROB".inp", "r")){
freopen(PROB".inp","r",stdin);
freopen(PROB".out","w",stdout);
}
}
void sinh_(){
// srand(time(0));
// freopen(PROB".inp" , "w" , stdout);
// int n;
}
typedef long long ll;
typedef double db;
const int N = 2e3 + 5;
const int dx[] = {-1, 1, 0, 0};
const int dy[] = {0, 0, -1, +1};
const int maxn = 2e3;
int n, m, k;
bool a[N][N], b[N][N];
int dist[N][N] = {}, d[N][N];
ll ans[N][N] = {}, Ans[N][N];
ll res = 0;
int pre_cnt[N*2][N*2] = {};
pair<ll, int> t[N][N] = {}, r[N][N] = {}, diagon[N * 2];
void readip(){
cin >> n >> m >> k;
REP(i, 1, n) REP(j, 1, m) cin >> a[i][j];
}
int cal(int x, int y, int xx, int yy) {
maximize(x, 1 - m);
minimize(xx, n - 1);
maximize(y, 2);
minimize(yy, n + m);
return pre_cnt[xx + maxn][yy]
+ pre_cnt[x - 1 + maxn][y - 1]
- pre_cnt[x - 1 + maxn][yy]
- pre_cnt[xx + maxn][y - 1];
}
void sub5() {
vector<vi> dist(n + 2, vi(m + 2, -1));
queue<pii> q;
REP(i, 1, n) REP(j, 1, m) if (a[i][j]) {
dist[i][j] = 0;
q.push(mp(i, j));
}
while(!q.empty()) {
int x = q.front().fi;
int y = q.front().se;
q.pop();
FOR(i, 4) {
int nx = x + dx[i], ny = y + dy[i];
if (nx < 0 || nx > n || ny < 0 || ny > m || dist[nx][ny] != -1) continue;
dist[nx][ny] = dist[x][y] + 1;
q.push(mp(nx, ny));
}
}
ll res = 0;
REP(i, 1, n) REP(j, 1, m) res += dist[i][j];
cout << res << ln;
}
void prepare() {
REP(i, 1, n) REP(j, 1, m) if (a[i][j])
pre_cnt[i - j + maxn][i + j] += 1;
REP(i, 1 - m + maxn, n - 1 + maxn) REP(j, 2, n + m)
pre_cnt[i][j] += pre_cnt[i - 1][j] + pre_cnt[i][j - 1] - pre_cnt[i - 1][j - 1];
memset(dist, -1, sizeof dist);
REP(d, 0, n + m) {
int tmp = cal(1 - 1 - d , 1 + 1 - d, 1 - 1 + d, 1 + 1 + d);
if (tmp >= k) {
dist[1][1] = d;
res -= 1LL * (tmp - k) * d;
break;
}
}
assert(dist[1][1] != -1);
REP(i, 1, n) REP(j, 1, m) {
if (i == 1 && j == 1) continue;
int D = (j == 1) ? dist[i - 1][j] : dist[i][j - 1];
REP(d, D - 1, D + 1) {
int tmp = cal(i - j - d, i + j - d, i - j + d, i + j + d);
if (tmp >= k) {
dist[i][j] = d;
res -= 1LL * (tmp - k) * d;
break;
}
}
assert(dist[i][j] != -1);
}
}
void xoay() { // i j -> j, n - i + 1
REP(i, 1, n) REP(j, 1, m) {
b[j][n - i + 1] = a[i][j];
d[j][n - i + 1] = dist[i][j];
Ans[j][n - i + 1] = ans[i][j];
}
swap(n, m);
REP(i, 1, n) REP(j, 1, m) {
a[i][j] = b[i][j];
dist[i][j] = d[i][j];
ans[i][j] = Ans[i][j];
}
}
void solve(){
if (k == 1) {
sub5();
return;
}
prepare();
FOR(dir, 4) {
REP(i, 0, n + m) diagon[i] = mp(0LL, 0);
REP(i, 0, n + 1) REP(j, 0, m + 1) t[i][j] = mp(0, 0), r[i][j] = mp(0, 0);
REP(i, 1, n) REPD(j, m, 1) {
t[i][j].fi = (a[i][j] ? i + j : 0) + t[i - 1][j].fi + t[i - 1][j + 1].fi - (i <= 2 ? 0 : t[i - 2][j + 1].fi);
t[i][j].se = (a[i][j] ? 1 : 0) + t[i - 1][j].se + t[i - 1][j + 1].se - (i <= 2 ? 0 : t[i - 2][j + 1].se);
r[i][j].fi = (a[i][j] ? i + j : 0) + r[i - 1][j].fi + r[i][j + 1].fi - r[i - 1][j + 1].fi;
r[i][j].se = (a[i][j] ? 1 : 0) + r[i - 1][j].se + r[i][j + 1].se - r[i - 1][j + 1].se;
diagon[i + j].fi += (a[i][j] ? i + j : 0);
diagon[i + j].se += (a[i][j] ? 1 : 0);
}
REP(i, 2, n + m) {
diagon[i].fi += diagon[i - 1].fi;
diagon[i].se += diagon[i - 1].se;
}
REP(i, 1, n) REP(j, 1, m) {
ll sum = t[min(n, i + dist[i][j])][j].fi - r[i - 1][j].fi;
int cnt = t[min(n, i + dist[i][j])][j].se - r[i - 1][j].se;
if (j + dist[i][j] + 1 <= m) {
sum -= t[i - 1][j + dist[i][j] + 1].fi;
sum += r[i - 1][j + dist[i][j] + 1].fi;
cnt -= t[i - 1][j + dist[i][j] + 1].se;
cnt += r[i - 1][j + dist[i][j] + 1].se;
}
if (i + dist[i][j] > n) {
int l = n + j + 1, r = min(n + m, i + j + dist[i][j]);
if (l <= r) {
sum += diagon[r].fi - diagon[l - 1].fi;
cnt += diagon[r].se - diagon[l - 1].se;
}
}
ans[i][j] += sum - 1LL * (i + j) * cnt;
}
xoay();
}
REP(i, 1, m) r[0][i] = mp(0, 0);
REP(i, 1, n) REP(j, 1, m) {
r[i][j].fi = r[i - 1][j].fi + (a[i][j] ? i : 0);
r[i][j].se = r[i - 1][j].se + (a[i][j] ? 1 : 0);
}
REP(i, 1, n) REP(j, 1, m) {
int L = max(1, i - dist[i][j]), R = i - 1;
if (L <= R) {
ll sum = r[R][j].fi - r[L - 1][j].fi;
int cnt = r[R][j].se - r[L - 1][j].se;
ans[i][j] -= 1LL * i * cnt - sum;
}
L = i + 1, R = min(n, i + dist[i][j]);
if (L <= R) {
ll sum = r[R][j].fi - r[L - 1][j].fi;
int cnt = r[R][j].se - r[L - 1][j].se;
ans[i][j] -= sum - 1LL * i * cnt;
}
}
REP(i, 1, n) r[i][0] = mp(0, 0);
REP(i, 1, n) REP(j, 1, m) {
r[i][j].fi = r[i][j - 1].fi + (a[i][j] ? j : 0);
r[i][j].se = r[i][j - 1].se + (a[i][j] ? 1 : 0);
}
REP(i, 1, n) REP(j, 1, m) {
int L = max(1, j - dist[i][j]), R = j - 1;
if (L <= R) {
ll sum = r[i][R].fi - r[i][L - 1].fi;
int cnt = r[i][R].se - r[i][L - 1].se;
ans[i][j] -= 1LL * j * cnt - sum;
}
L = j + 1, R = min(m, j + dist[i][j]);
if (L <= R) {
ll sum = r[i][R].fi - r[i][L - 1].fi;
int cnt = r[i][R].se - r[i][L - 1].se;
ans[i][j] -= sum - 1LL * j * cnt;
}
}
REP(i, 1, n) REP(j, 1, m) res += ans[i][j];
cout << res << ln;
}
int main(){
sinh_();
io_faster
file();
int t = 1;
// cin >> t;
while (t--){
readip();
solve();
}
}

#include <cassert>
#include <cctype>
#include <cerrno>
#include <cfloat>
#include <ciso646>
#include <climits>
#include <clocale>
#include <cmath>
#include <csetjmp>
#include <csignal>
#include <cstdarg>
#include <cstddef>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <ccomplex>
#include <cfenv>
#include <cinttypes>
#include <cstdbool>
#include <cstdint>
#include <ctgmath>
#include <cwchar>
#include <cwctype>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <exception>
#include <fstream>
#include <functional>
#include <iomanip>
#include <ios>
#include <iosfwd>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <locale>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <stdexcept>
#include <streambuf>
#include <string>
#include <typeinfo>
#include <utility>
#include <valarray>
#include <vector>
#include <array>
#include <atomic>
#include <chrono>
#include <condition_variable>
#include <forward_list>
#include <future>
#include <initializer_list>
#include <mutex>
#include <random>
#include <ratio>
#include <regex>
#include <scoped_allocator>
#include <system_error>
#include <thread>
#include <tuple>
#include <typeindex>
#include <type_traits>
#include <unordered_map>
#include <unordered_set>

using namespace std;
#define pb push_back
#define eb emplace_back
#define mp make_pair
#define pii pair<int,int>
#define pll pair<long long , long long>
#define vi vector<int>
#define vpii vector<pii>
#define SZ(x) ((int)(x.size()))
#define fi first
#define se second
#define IN(x,y) ((y).find((x))!=(y).end())
#define ALL(t) t.begin(),t.end()
#define FOREACH(i,t) for (typeof(t.begin()) i=t.begin(); i!=t.end(); i++)
#define REP(i,a,b) for(int (i)=(a);(i)<=(b);++i)
#define REPD(i,a,b) for(int (i)=(a); (i)>=(b);--i)
#define FOR(i, n) for (int (i) = 0; (i) < (n); ++(i))
#define dem(x) __builtin_popcount(x)
#define Mask(x) (1LL << (x))
#define BIT(x, i) ((x) >> (i) & 1)
#define ln '\n'
#define io_faster ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
///mt19937 rnd(time(0));

const int INF = 1e9 , mod = 1e9 + 7;

template <class T1, class T2>
inline T1 mul(T1& x, const T2 &k){ return x = (1LL * x * k) % mod; }

template <class T1 , class T2>
inline T1 pw(T1 x, T2 k){T1 res = 1; for (; k ; k >>= 1){ if (k & 1) mul(res, x); mul(x, x); } return res;}

template <class T>
inline bool minimize(T &x, const T &y){ if (x > y){x = y; return 1;} return 0; }

template <class T>
inline bool maximize(T &x, const T &y){ if (x < y){x = y; return 1;} return 0; }

template <class T>
inline void add(T &x , const T &y){ if ((x += y) >= mod) x -= mod; }

template <class T>
inline T product (const T &x , const T &y) { return 1LL * x * y % mod; }

#define PROB "formation"
void file(){
    if(fopen(PROB".inp", "r")){
        freopen(PROB".inp","r",stdin);
        freopen(PROB".out","w",stdout);
    }
}
void sinh_(){
//    srand(time(0));
//    freopen(PROB".inp" , "w" , stdout);
//    int n;
}

typedef long long ll;
typedef double db;
const int N = 2e3 + 5;
const int dx[] = {-1, 1, 0, 0};
const int dy[] = {0, 0, -1, +1};
const int maxn = 2e3;

int n, m, k;
bool a[N][N], b[N][N];
int dist[N][N] = {}, d[N][N];
ll ans[N][N] = {}, Ans[N][N];
ll res = 0;
int pre_cnt[N*2][N*2] = {};
pair<ll, int> t[N][N] = {}, r[N][N] = {}, diagon[N * 2];

void readip(){
    cin >> n >> m >> k;
    REP(i, 1, n) REP(j, 1, m) cin >> a[i][j];
}

int cal(int x, int y, int xx, int yy) {
    maximize(x, 1 - m);
    minimize(xx, n - 1);
    maximize(y, 2);
    minimize(yy, n + m);
    return pre_cnt[xx + maxn][yy] 

        + pre_cnt[x - 1 + maxn][y - 1] 
        - pre_cnt[x - 1 + maxn][yy] 
        - pre_cnt[xx + maxn][y - 1];
}

void sub5() {
    vector<vi> dist(n + 2, vi(m + 2, -1));
    queue<pii> q;
    REP(i, 1, n) REP(j, 1, m) if (a[i][j]) {
        dist[i][j] = 0;
        q.push(mp(i, j));
    }
    while(!q.empty()) {
        int x = q.front().fi;
        int y = q.front().se;
        q.pop();
        FOR(i, 4) {
            int nx = x + dx[i], ny = y + dy[i];
            if (nx < 0 || nx > n || ny < 0 || ny > m || dist[nx][ny] != -1) continue;
            dist[nx][ny] = dist[x][y] + 1;
            q.push(mp(nx, ny));
        }
    }
    ll res = 0;
    REP(i, 1, n) REP(j, 1, m) res += dist[i][j];
    cout << res << ln;
}


void prepare() {
    REP(i, 1, n) REP(j, 1, m) if (a[i][j]) 
        pre_cnt[i - j + maxn][i + j] += 1;

    REP(i, 1 - m + maxn, n - 1 + maxn)  REP(j, 2, n + m) 
        pre_cnt[i][j] += pre_cnt[i - 1][j] + pre_cnt[i][j - 1] - pre_cnt[i - 1][j - 1];

    memset(dist, -1, sizeof dist);
    REP(d, 0, n + m) {
        int tmp = cal(1 - 1 - d , 1 + 1 - d, 1 - 1 + d, 1 + 1 + d);
        if (tmp >= k) {
            dist[1][1] = d;
            res -= 1LL * (tmp - k) * d;
            break;
        }
    }

    assert(dist[1][1] != -1);

    REP(i, 1, n) REP(j, 1, m) {
        if (i == 1 && j == 1) continue;
        int D = (j == 1) ? dist[i - 1][j] : dist[i][j - 1];
        REP(d, D - 1, D + 1) {
            int tmp = cal(i - j - d, i + j - d, i - j + d, i + j + d);
            if (tmp >= k) {
                dist[i][j] = d;
                res -= 1LL * (tmp - k) * d;
                break;
            }
        }
        assert(dist[i][j] != -1);
    }
}

void xoay() { // i j -> j, n - i + 1
    REP(i, 1, n) REP(j, 1, m) {
        b[j][n - i + 1] = a[i][j];
        d[j][n - i + 1] = dist[i][j];
        Ans[j][n - i + 1] = ans[i][j];
    }

    swap(n, m);

    REP(i, 1, n) REP(j, 1, m) {
        a[i][j] = b[i][j];
        dist[i][j] = d[i][j];
        ans[i][j] = Ans[i][j];
    }
}

void solve(){  
    if (k == 1) {
        sub5();
        return;
    }

    prepare();  
    FOR(dir, 4) {
        REP(i, 0, n + m) diagon[i] = mp(0LL, 0);
        REP(i, 0, n + 1) REP(j, 0, m + 1) t[i][j] = mp(0, 0), r[i][j] = mp(0, 0);

        REP(i, 1, n) REPD(j, m, 1) {
            t[i][j].fi = (a[i][j] ? i + j : 0) + t[i - 1][j].fi + t[i - 1][j + 1].fi - (i <= 2 ? 0 : t[i - 2][j + 1].fi);
            t[i][j].se = (a[i][j] ? 1 : 0)     + t[i - 1][j].se + t[i - 1][j + 1].se - (i <= 2 ? 0 : t[i - 2][j + 1].se);   

            r[i][j].fi = (a[i][j] ? i + j : 0) + r[i - 1][j].fi + r[i][j + 1].fi - r[i - 1][j + 1].fi;
            r[i][j].se = (a[i][j] ? 1 : 0)     + r[i - 1][j].se + r[i][j + 1].se - r[i - 1][j + 1].se;

            diagon[i + j].fi += (a[i][j] ? i + j : 0);
            diagon[i + j].se += (a[i][j] ? 1 : 0);
        }



        REP(i, 2, n + m) {
            diagon[i].fi += diagon[i - 1].fi;
            diagon[i].se += diagon[i - 1].se;
        }

        REP(i, 1, n) REP(j, 1, m) {
            ll sum = t[min(n, i + dist[i][j])][j].fi - r[i - 1][j].fi;
            int cnt = t[min(n, i + dist[i][j])][j].se - r[i - 1][j].se;

            if (j + dist[i][j] + 1 <= m)  {
                sum -= t[i - 1][j + dist[i][j] + 1].fi;
                sum += r[i - 1][j + dist[i][j] + 1].fi;

                cnt -= t[i - 1][j + dist[i][j] + 1].se;
                cnt += r[i - 1][j + dist[i][j] + 1].se;
            }


            if (i + dist[i][j] > n) {
                int l = n + j + 1, r = min(n + m, i + j + dist[i][j]);
                if (l <= r) {
                    sum += diagon[r].fi - diagon[l - 1].fi;
                    cnt += diagon[r].se - diagon[l - 1].se;
                }
            }

            ans[i][j] += sum - 1LL * (i + j) * cnt;
        }
        xoay();
    }


    REP(i, 1, m) r[0][i] = mp(0, 0);
    REP(i, 1, n) REP(j, 1, m) {
        r[i][j].fi = r[i - 1][j].fi + (a[i][j] ? i : 0);
        r[i][j].se = r[i - 1][j].se + (a[i][j] ? 1 : 0);
    }

    REP(i, 1, n) REP(j, 1, m) {
        int L = max(1, i - dist[i][j]), R = i - 1;
        if (L <= R) {
            ll sum = r[R][j].fi - r[L - 1][j].fi;
            int cnt = r[R][j].se - r[L - 1][j].se;
            ans[i][j] -= 1LL * i * cnt - sum;
        }
        L = i + 1, R = min(n, i + dist[i][j]);
        if (L <= R) {
            ll sum = r[R][j].fi - r[L - 1][j].fi;
            int cnt = r[R][j].se - r[L - 1][j].se;
            ans[i][j] -= sum - 1LL * i * cnt;
        }
    }
    REP(i, 1, n) r[i][0] = mp(0, 0);
    REP(i, 1, n) REP(j, 1, m) {
        r[i][j].fi = r[i][j - 1].fi + (a[i][j] ? j : 0);
        r[i][j].se = r[i][j - 1].se + (a[i][j] ? 1 : 0);
    }
    REP(i, 1, n) REP(j, 1, m) {
        int L = max(1, j - dist[i][j]), R = j - 1;
        if (L <= R) {
            ll sum = r[i][R].fi - r[i][L - 1].fi;
            int cnt = r[i][R].se - r[i][L - 1].se;
            ans[i][j] -= 1LL * j * cnt - sum;
        }
        L = j + 1, R = min(m, j + dist[i][j]);
        if (L <= R) {
            ll sum = r[i][R].fi - r[i][L - 1].fi;
            int cnt = r[i][R].se - r[i][L - 1].se;
            ans[i][j] -= sum - 1LL * j * cnt;
        }
    }

    REP(i, 1, n)  REP(j, 1, m) res += ans[i][j];
    cout << res << ln;
}

int main(){
    sinh_();
    io_faster
    file();
    int t = 1;
//    cin >> t;
    while (t--){
        readip();
        solve();
    }
}
