#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_pbds;
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define fbo find_by_order
#define ook order_of_key
typedef long long ll;
typedef pair<ll,ll> ii;
typedef vector<int> vi;
typedef long double ld;
typedef tree<int, null_type, less<int>, rb_tree_tag, tree_order_statistics_node_update> pbds;
typedef set<int>::iterator sit;
typedef map<int,int>::iterator mit;
typedef vector<int>::iterator vit;
int a[2001][2001];
int pos[2001];
int main()
{
ios_base::sync_with_stdio(0); cin.tie(0);
int n, k; cin >> n >> k;
for(int i = 0; i < n; i++)
{
for(int j = 0; j < k; j++)
{
cin >> a[i][j];
}
}
memset(pos, 0, sizeof(pos));
priority_queue<ii, vector<ii>, greater<ii> > pq;
for(int i = 0; i < n; i++)
{
pq.push(mp(0, i));
}
ll ans = 0;
for(int i = 0; i < n*(k+1); i++)
{
if(pq.empty()) continue;
int tmp = pq.top().se; ll score = pq.top().fi;
pq.pop();
if(pos[tmp] >= k) continue;
//cerr<<tmp<<' '<<score<<'\n';
score += a[tmp][pos[tmp]];
pos[tmp]++;
if(pq.empty()) continue;
if((score > pq.top().fi)||(score == pq.top().fi && tmp > pq.top().se))
{
ans++;
//cerr<<"FAIL : "<<pq.top().se<<' '<<pq.top().fi<<" vs "<<tmp<<' '<<score<<'\n';
}
pq.push(mp(score,tmp));
}
cout<<ans<<'\n';
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4KI2luY2x1ZGUgPGV4dC9wYl9kcy90cmVlX3BvbGljeS5ocHA+CiAKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKdXNpbmcgbmFtZXNwYWNlIF9fZ251X3BiZHM7CiAKI2RlZmluZSBmaSBmaXJzdAojZGVmaW5lIHNlIHNlY29uZAojZGVmaW5lIG1wIG1ha2VfcGFpcgojZGVmaW5lIHBiIHB1c2hfYmFjawojZGVmaW5lIGZibyBmaW5kX2J5X29yZGVyCiNkZWZpbmUgb29rIG9yZGVyX29mX2tleQogCnR5cGVkZWYgbG9uZyBsb25nIGxsOwp0eXBlZGVmIHBhaXI8bGwsbGw+IGlpOwp0eXBlZGVmIHZlY3RvcjxpbnQ+IHZpOwp0eXBlZGVmIGxvbmcgZG91YmxlIGxkOyAKdHlwZWRlZiB0cmVlPGludCwgbnVsbF90eXBlLCBsZXNzPGludD4sIHJiX3RyZWVfdGFnLCB0cmVlX29yZGVyX3N0YXRpc3RpY3Nfbm9kZV91cGRhdGU+IHBiZHM7CnR5cGVkZWYgc2V0PGludD46Oml0ZXJhdG9yIHNpdDsKdHlwZWRlZiBtYXA8aW50LGludD46Oml0ZXJhdG9yIG1pdDsKdHlwZWRlZiB2ZWN0b3I8aW50Pjo6aXRlcmF0b3Igdml0OwogCmludCBhWzIwMDFdWzIwMDFdOwppbnQgcG9zWzIwMDFdOwogCmludCBtYWluKCkKewoJaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbygwKTsgY2luLnRpZSgwKTsKCWludCBuLCBrOyBjaW4gPj4gbiA+PiBrOwoJZm9yKGludCBpID0gMDsgaSA8IG47IGkrKykKCXsKCQlmb3IoaW50IGogPSAwOyBqIDwgazsgaisrKQoJCXsKCQkJY2luID4+IGFbaV1bal07CgkJfQoJfQoJbWVtc2V0KHBvcywgMCwgc2l6ZW9mKHBvcykpOwoJcHJpb3JpdHlfcXVldWU8aWksIHZlY3RvcjxpaT4sIGdyZWF0ZXI8aWk+ID4gcHE7Cglmb3IoaW50IGkgPSAwOyBpIDwgbjsgaSsrKQoJewoJCXBxLnB1c2gobXAoMCwgaSkpOwoJfQoJbGwgYW5zID0gMDsKCWZvcihpbnQgaSA9IDA7IGkgPCBuKihrKzEpOyBpKyspCgl7CgkJaWYocHEuZW1wdHkoKSkgY29udGludWU7CgkJaW50IHRtcCA9IHBxLnRvcCgpLnNlOyBsbCBzY29yZSA9IHBxLnRvcCgpLmZpOwoJCXBxLnBvcCgpOwoJCWlmKHBvc1t0bXBdID49IGspIGNvbnRpbnVlOwoJCS8vY2Vycjw8dG1wPDwnICc8PHNjb3JlPDwnXG4nOwoJCXNjb3JlICs9IGFbdG1wXVtwb3NbdG1wXV07CgkJcG9zW3RtcF0rKzsKCQlpZihwcS5lbXB0eSgpKSBjb250aW51ZTsKCQlpZigoc2NvcmUgPiBwcS50b3AoKS5maSl8fChzY29yZSA9PSBwcS50b3AoKS5maSAmJiB0bXAgPiBwcS50b3AoKS5zZSkpCgkJewoJCQlhbnMrKzsKCQkJLy9jZXJyPDwiRkFJTCA6ICI8PHBxLnRvcCgpLnNlPDwnICc8PHBxLnRvcCgpLmZpPDwiIHZzICI8PHRtcDw8JyAnPDxzY29yZTw8J1xuJzsKCQl9CgkJcHEucHVzaChtcChzY29yZSx0bXApKTsKCX0KCWNvdXQ8PGFuczw8J1xuJzsKfQog