from collections import defaultdict
l = int(input())
for _ in range(0, l):
n, x = map(int, input().split())
numbers = [int(i) for i in input().split()]
numbers.sort()
d = defaultdict(int)
for i in numbers:
d[i] += 1
ans = len(numbers)
for key in d:
if key % x == 0 and key//x in d and d[key // x]:
ans -= (2*min(d[key // x], d[key]))
minimal = min(d[key // x], d[key])
d[key // x] -= minimal
d[key] -= minimal
print(ans)
#include <bits/stdc++.h>
using namespace std;
#define io ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define endl "\n"
#define fr1( i, a, n ) for( long long i = a; i < n; i++ )
#define fr( i, n ) for( long long i = 0; i < n; i++ )
#define rf( i, n ) for( long long i = n-1; i >= 0; i-- )
#define py cout << "YES\n";
#define pyy cout << "Yes\n";
#define pn cout << "NO\n";
#define pnn cout << "No\n";
#define all(v) v.begin(),v.end()
#define pb push_back
#define vll vector<long long>
#define mll map<long long,long long>
#define vpll vector<pair<long long,long long>>
#define lb(v,x) lower_bound(all(v),x)-v.begin()
#define ub(v,x) upper_bound(all(v),x)-v.begin()
#define precision(a) cout << fixed << setprecision(a)
#define mem(x,y) memset(x,y,sizeof(x))
#define pll pair<ll,ll>
#define sr(a) sort(all(a))
#define srg(a) sort(all(a),greater<>())
#define re return;
#define acc(a) accumulate(all(a),0LL)
#define int long long
typedef long long ll;
template <typename T> T myfloor( T a, T b ){ return a/b; } // careful for negetive numbers
template <typename T> T myceil( T a, T b ){ return (a+b-1)/b; }
template <typename T> T mysqrt( T x ){ T ans = 0;for (T k = 1 << 30; k != 0; k /= 2) {if ((ans + k) * (ans + k) <= x) {ans += k;}}return ans;}
template <typename T> T Sqr(T x) { T n = x * x ; return n ;}
template <typename T> T Pow(T B,T P){ if(P==0) return 1; if(P&1) return B*Pow(B,P-1); else return Sqr(Pow(B,P/2));}
// Operator overloads
template<typename T1, typename T2> /*cin >> pair<T1, T2>*/ istream& operator>>(istream &istream, pair<T1, T2> &p) { return (istream >> p.first >> p.second); }
template<typename T> /* // cin >> vector<T> */istream& operator>>(istream &istream, vector<T> &v){for (auto &it : v)cin >> it;return istream;}
template<typename T1, typename T2> /* // cout << pair<T1, T2> */ostream& operator<<(ostream &ostream, const pair<T1, T2> &p) { return (ostream << p.first << " " << p.second); }
template<typename T> /* // cout << vector<T> */ostream& operator<<(ostream &ostream, const vector<T> &c) { for (auto &it : c) cout << it << " "; return ostream; }
//Bits
string decToBinary(int n){string s="";int i = 0;while (n > 0) {s =to_string(n % 2)+s;n = n / 2;i++;}return s;}
ll binaryToDecimal(string n){string num = n;ll dec_value = 0;int base = 1;int len = num.length();for(int i = len - 1; i >= 0; i--){if (num[i] == '1')dec_value += base;base = base * 2;}return dec_value;}
void fast(){
io;
#ifndef ONLINE_JUDGE
freopen("input.txt","r",stdin);
/*freopen("output.txt","w",stdout);*/
#endif
}
// priority_queue <int, vector<int>, greater<int>> q;
const int maxn = 2e5 + 14, mod = 1e9 + 7;
template <typename T> T BigMod (T b,T p,T m){if (p == 0) return 1;if (p%2 == 0){T s = BigMod(b,p/2,m);return ((s%m)*(s%m))%m;}return ((b%m)*(BigMod(b,p-1,m)%m))%m;}
ll nCr(ll n, ll m){ ll s = 1;for (ll i = n - m + 1; i <= n; i++) {s = s * i / (i - n + m); }return s;}
template <typename T> T ModInv (T b,T m){return BigMod(b,m-2,m);}
template <typename T> T lcm(T a,T b) {if(a<0)return lcm(-a,b);if(b<0)return lcm(a,-b);return a*(b/gcd(a,b));}
void solve(){
// ll n; cin >> n;
// vll a(n); for ( int i = 0; i < n; i++ ) cin >> a[i];
int n, m; cin >> n >> m;
vll a(n); for ( int i = 0; i < n; i++ ) cin >> a[i];
mll mp;
fr ( i, n ){
mp[a[i]]++;
}
sr(a);
int ans = 0;
fr ( i, n ){
if ( mp.find(a[i]) == mp.end() ){
continue;
}
if ( mp.find(m*a[i]) != mp.end() ){
mp[a[i]]--;
mp[a[i]*m]--;
if ( mp[a[i]] == 0 ) mp.erase(a[i]);
if ( mp[a[i]*m] == 0 ) mp.erase(a[i]*m);
} else {
if ( mp.find(m*a[i]) == mp.end() )
ans++;
mp[a[i]]--;
if ( mp[a[i]] == 0 ) mp.erase(a[i]);
}
}
cout << ans << endl;
}
signed main(){
// class Timer { private: chrono::time_point <chrono::steady_clock> Begin, End; public: Timer () : Begin(), End (){ Begin = chrono::steady_clock::now(); } ~Timer () { End = chrono::steady_clock::now();cerr << "\nDuration: " << ((chrono::duration <double>)(End - Begin)).count() << "s\n"; } } T;
fast();
ll tt = 1;
cin >> tt;
ll i = 1;
while ( tt-- > 0 ){
// cout << "Case " << i++ << ": ";
solve();
}
return 0;
}
732B - Cormen --- The Best Friend Of a Man | 1369A - FashionabLee |
1474B - Different Divisors | 1632B - Roof Construction |
388A - Fox and Box Accumulation | 451A - Game With Sticks |
768A - Oath of the Night's Watch | 156C - Cipher |
545D - Queue | 459B - Pashmak and Flowers |
1538A - Stone Game | 1454C - Sequence Transformation |
165B - Burning Midnight Oil | 17A - Noldbach problem |
1350A - Orac and Factors | 1373A - Donut Shops |
26A - Almost Prime | 1656E - Equal Tree Sums |
1656B - Subtract Operation | 1656A - Good Pairs |
1367A - Short Substrings | 87A - Trains |
664A - Complicated GCD | 1635D - Infinite Set |
1462A - Favorite Sequence | 1445B - Elimination |
1656C - Make Equal With Mod | 567A - Lineland Mail |
1553A - Digits Sum | 1359B - New Theatre Square |