题目传送门
一道水题
先上代码:
#include<iostream>
#include<iostream>
#include<cstdio>
#include<set>
#include<algorithm>
using namespace std;
long long a[100005];
set<long long> s;
int n, k;
int main()
{
cin >> n >> k;
for(int i = 1; i <= n; i++)
{
cin >> a[i]; // 和蔼可亲的输入
}
sort(a + 1, a + 1 + n); // 简单的排序
for(int i = 1; i <= n; i++)
{
if(a[i] % k || !s.count(a[i] / k)) // 貌似就这一句难懂点
{
s.insert(a[i]);
}
}
cout << s.size() << endl;
return 0;
}
根据题意:
a[i] % k
在条件中表示a[i] % k
不等于 0,因为 x 题意中一定是整数,所以当然不可能有a[i] = kx
了。!s.count(a[i] / k)
代表集合s
不包含a[i] / k
,所以也就不会有哪个数出现y = kx
的情况了。因为,x
根本就不存在。
谢谢观看蒟蒻的题解qwq