#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
inline int power(int a, int b) {
int x = 1;
while (b) {
if (b & 1) x *= a;
a *= a;
b >>= 1;
}
return x;
}
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int LINF = 2000000000000000001;
//_ ***************************** START Below *******************************
//? Good Subarrays Hashing
//* We need to find subarrays : (P[R] - P[L-1])%k == 0
//* P[R]%k == P[L-1]%k
//* Hence for P[R]%k find P[R]%k in past
//* Eg : [4, 5, 0, -2, -3, 1] , k = 5
//* sum : 0 4 9 9 7 4 5
//* sum%m : 0 4 4 4 2 4 0
//* ct : 1 1 2 3 1 4 2
//* ans : 1 + 2 + 0 + 3 + 1
vector<int> a;
void consistency(int n, int k) {
unordered_map<int,int> mp = {{0, 1}};
int sum = 0;
int ans = 0;
for(int i=0; i<n; i++){
sum += a[i];
int rem = ((sum%k)+k)%k;
if(mp.count(rem)){
ans += mp[rem];
}
mp[rem]++;
}
cout << ans << endl;
}
void solve() {
int n, k;
cin >> n >> k;
a.resize(n);
for(int i=0; i<n; i++) cin >> a[i];
consistency(n, k) ;
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t = 1;
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQppbmxpbmUgaW50IHBvd2VyKGludCBhLCBpbnQgYikgewogICAgaW50IHggPSAxOwogICAgd2hpbGUgKGIpIHsKICAgICAgICBpZiAoYiAmIDEpIHggKj0gYTsKICAgICAgICBhICo9IGE7CiAgICAgICAgYiA+Pj0gMTsKICAgIH0KICAgIHJldHVybiB4Owp9CgoKY29uc3QgaW50IE0gPSAxMDAwMDAwMDA3Owpjb25zdCBpbnQgTiA9IDNlNSs5Owpjb25zdCBpbnQgSU5GID0gMmU5KzE7CmNvbnN0IGludCBMSU5GID0gMjAwMDAwMDAwMDAwMDAwMDAwMTsKCi8vXyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiBTVEFSVCBCZWxvdyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgoKCgovLz8gR29vZCBTdWJhcnJheXMgSGFzaGluZwoKLy8qIFdlIG5lZWQgdG8gZmluZCBzdWJhcnJheXMgOiAoUFtSXSAtIFBbTC0xXSklayA9PSAwCi8vKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgUFtSXSVrID09IFBbTC0xXSVrCi8vKiAgICAgSGVuY2UgZm9yIFBbUl0layBmaW5kIFBbUl0layBpbiBwYXN0CgoKLy8qIEVnICAgICA6ICAgIFs0LCAgNSwgIDAsIC0yLCAtMywgIDFdICAgLCBrID0gNQovLyogc3VtICAgIDogIDAgIDQgICA5ICAgOSAgIDcgICA0ICAgNSAgICAgCi8vKiBzdW0lbSAgOiAgMCAgNCAgIDQgICA0ICAgMiAgIDQgICAwICAgICAKLy8qIGN0ICAgICA6ICAxICAxICAgMiAgIDMgICAxICAgNCAgIDIKLy8qIGFucyAgICA6ICAgICAgICAgMSArIDIgKyAwICsgMyArIDEKCgp2ZWN0b3I8aW50PiBhOwp2b2lkIGNvbnNpc3RlbmN5KGludCBuLCBpbnQgaykgewoJCgl1bm9yZGVyZWRfbWFwPGludCxpbnQ+IG1wID0ge3swLCAxfX07CglpbnQgc3VtID0gMDsKCWludCBhbnMgPSAwOwoJZm9yKGludCBpPTA7IGk8bjsgaSsrKXsKCSAgICBzdW0gKz0gYVtpXTsKCSAgICBpbnQgcmVtID0gKChzdW0laykrayklazsKCSAgICBpZihtcC5jb3VudChyZW0pKXsKCSAgICAgICAgYW5zICs9IG1wW3JlbV07CgkgICAgfQoJICAgIG1wW3JlbV0rKzsKCX0KCQoJY291dCA8PCBhbnMgPDwgZW5kbDsKCn0KCnZvaWQgc29sdmUoKSB7CiAgICAKCWludCBuLCBrOwoJY2luID4+IG4gPj4gazsKCWEucmVzaXplKG4pOwoJZm9yKGludCBpPTA7IGk8bjsgaSsrKSBjaW4gPj4gYVtpXTsKICAgIGNvbnNpc3RlbmN5KG4sIGspIDsKCn0KCgoKCgppbnQzMl90IG1haW4oKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKCiAgICBpbnQgdCA9IDE7CiAgICB3aGlsZSAodC0tKSB7CiAgICAgICAgc29sdmUoKTsKICAgIH0KCiAgICByZXR1cm4gMDsKfQ==