K-th Number

自己写的judge函数太丑了,还是错的
//类似滑动窗口

bool judge(int x){
	 int ans=0;int i;int cnt=0;
	for (i=1;i<=n;i++)
	   {
	   if(a[i]>=x) cnt++;
        if (cnt>=k)  break;
	   }
	   ans+=n-i+1;
	   int j=1;
	while (i<=n)
	{
    while (j<=n&&a[j]<x){
        ans+=n-i+1;
        j++;
        }
       while (a[i]<x) i++; 
    }
    return ans<x;
}

正解代码

#include<cstdio>
using namespace std;
typedef long long ll;
int n,k;
ll m;
int a[100005];
bool judge(int x){
	 int ans=0;int i;int cnt=0;
	for (i=1;i<=n;i++)
	   {
	   if(a[i]>=x) cnt++;
        if (cnt>=k)  break;
	   }
	   ans+=n-i+1;
	   int j=1;
	while (i<=n)
	{
    while (j<=n&&a[j]<x){
        ans+=n-i+1;
        j++;
        }
       while (a[i]<x) i++; 
    }
    return ans<x;
}
int main(){
 int T;
 scanf("%d",&T);
 while (T--){
 	scanf("%d%d%lld",&n,&k,&m);
 	for (int i=1;i<=n;i++)
 	  scanf("%d",&a[i]);
 	  int l=1,r=10000000000;
 	  int mid;
 	  while (l<r){
 	  	 mid=(l+r)>>1;
 	  	 if (judge(mid)) l=mid+1;
 	  	 else r=mid;
	   }
	   printf("%d\n",l-1);
   }
  return 0;
}
全部评论

相关推荐

收到了小米的实习offer,犹豫是否要去。。。
认真搞学习:雷总还当过首富呢,公司不算大厂算独角兽吗
点赞 评论 收藏
分享
05-09 14:45
门头沟学院 Java
点赞 评论 收藏
分享
迷茫的大四🐶:自信一点,我认为你可以拿到50k,低于50k完全配不上你的能力,兄弟,不要被他们骗了,你可以的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务