当前位置:   article > 正文

二分法求最小值的最大下标_二分法求下标最大的那个xi的下标

二分法求下标最大的那个xi的下标

写一个函数LowerBound,在包含n个元素的int数组a里查找比给定整数p小的,下标最大的元素。找到则返回起下标,找不到则返回-1

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. using namespace std;
  5. bool cmp(int a,int b){
  6. return a<b;
  7. }
  8. int LowerBound(int a[],int n,int p){
  9. int l=0;
  10. int h=n-1;
  11. int x=-1;
  12. while(l<=h){
  13. int mid=l+(h-l)/2;
  14. if(a[mid]>=p){
  15. h=mid-1;// 太大了,变小一点
  16. }else{
  17. x=mid;//保存目前最符合的值
  18. l=mid+1;//试试更大的行不行
  19. }
  20. }
  21. return x;
  22. }
  23. int main(){
  24. int n,p,i;
  25. int t;
  26. scanf("%d %d",&n,&p);
  27. int a[n];
  28. for(i=0;i<n;i++){
  29. scanf("%d",&a[i]);
  30. }
  31. sort(a,a+n,cmp);
  32. t=LowerBound(a,n,p);
  33. if(t!=-1){
  34. printf("%d",t);
  35. }else{
  36. printf("NO");
  37. }
  38. }

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/227648
推荐阅读
相关标签
  

闽ICP备14008679号