代码拉取完成,页面将自动刷新
class Solution {
public int[] kthSmallestPrimeFraction(int[] A, int k) {
Arrays.sort(A);
double gap=(A[0]+0.0)/A[A.length-1];
double l=gap,r=1.0;
for(int i=0;i<A.length/2;i++){
int temp = A[i];
A[i] = A[A.length - i - 1];
A[A.length - i - 1] = temp;
}
int res[]=new int[2];
while(r-l>=0.00000001){
double mid=l+(r-l)/2;
Queue<Integer>q=new LinkedList<>();
int cnt=0;
double max=-1;
int arr[]=new int[2];
for(int i=0;i<A.length;i++){
double cur=A[i];
while(q.size()>0&&(cur/q.peek())<=mid){
int peek=q.poll();
double curM=cur/peek;
if(curM>max){
max=curM;
arr[0]=A[i];
arr[1]=peek;
}
}
q.add(A[i]);
cnt+=(i+1-q.size());
}
if(cnt>=k){
res=arr;
r=mid-0.0000001;
}else{
l=mid+0.0000001;
}
}
return res;
}
}
//5 3 2 1
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。