#include using namespace std; #define int long long int32_t main(){ int n, p; cin >> n >> p; vector a(n); for(auto& x : a) cin >> x; vector tank = {p}; for(int i = 0; i < 60; i++){ if(tank.back() > 1e9) break; tank.push_back(tank.back() * p); } int ans = 0; for(int v : tank){ map mp; for(int i = 0; i < n; i++){ mp[a[i] % v]++; } for(auto[key, val] : mp){ ans += val * (val - 1) / 2; } } cout << ans << endl; return 0; }