给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列。
现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列。
输入描述:
输入第一行给出两个正整数N和p,其中N(<= 105)是输入的正整数的个数,p(<= 109)是给定的参数。第二行给出N个正整数,每个数 不超过109。
输出描述:
在一行中输出最多可以选择多少个数可以用它们组成一个完美数列。
示例1
输入
10 8 2 3 20 4 5 1 6 7 8 9
输出
8
解题思路:将排序好的数列从前向后遍历,找到满足条件的个数即可
采用二分法实现
#include<bits/stdc++.h>
using namespace std;
const int N=100010;
typedef long long ll;
ll a[N];
int main(){
int n,p;
scanf("%d%d",&n,&p);
for(int i=0;i<n;i++){
scanf("%ld",&a[i]);
}
sort(a,a+n);
ll k;
int cnt=0,maxn=0,res;
for(int i=0;i<n;i++){
k=a[i]*p;
res=upper_bound(a+i,a+n,k)-a;
maxn=max(maxn,res-i);
}
printf("%d\n",maxn);
return 0;
}
/*
10 8
2 3 20 4 5 1 6 7 8 9
*/