题目 |
题目描述
给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列。
现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列。
输入描述:
输入第一行给出两个正整数N和p,其中N(<= 10^5)是输入的正整数的个数,p(<= 10^9)是给定的参数。第二行给出N个正整数,每个数不超过10^9。
输出描述:
在一行中输出最多可以选择多少个数可以用它们组成一个完美数列。
输入例子:
10 8
2 3 20 4 5 1 6 7 8 9
输出例子:
8
解题思路 |
1. 对题目的数据存储至数组中,并对数组进行排序,然后遍历即可
2. 如果直接一一遍历比较的话,肯定会超时,所以需要采取个小技巧,即用maxn表示目前可以组成的最多数目,遍历时a[ i ]为初始位置,a[ j ]为末位置,a[j]>a[i]*p且j>=i+maxn
//主要算法
//zhicheng
sort(a.begin(),a.end());//排序
for(int i=0;i<n&&maxn<n-i;i++)
{//查找可以组成完美数列的最多元素
for(int j=i+maxn;j<n;j++)
{
if(a[j]>a[i]*p) break;
maxn++;
}
}
printf("%d\n",maxn);
![这里写图片描述](https://i-blog.csdnimg.cn/blog_migrate/89e76ae04b4d3f9a3dd83cf7687f6898.gif)