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;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 14:55
点赞 评论 收藏
分享
代码飞升:别用口语,后端就写后端,前端就写前端,最后别光后悔
点赞 评论 收藏
分享
06-18 15:03
门头沟学院 Java
至少实习看起来比去年好?问了下群里的同学和身边的同学,人均有offer。有的还有好几个大厂offer
菜鸟1973:上一年暑期也是人均大厂实习offer,结果秋招跟不招人一样,大部分都转正了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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