JAVA实现lowerBound和upperBound函数

JAVA实现lowerBound和upperBound函数

//找到第一个大于等于x的位置
        public static int lowerBound(User[] user , int low, int high, int x){
                int mid;
                while (low <= high){
                        mid = (low + high)>>1;
                        if(user[mid].likeValue >= x)
                                high = mid-1;
                        else
                                low = mid+1;

                }
                return low;
        }
 //找到第一个大于x的位置
        public static int upperBound(User[] user, int low, int high, int x){
                int mid;
                while (low<high){
                        mid = (low+high)>>1;
                        if(user[mid].likeValue<=x)
                                low = mid+1;
                        else
                                high = mid;
                }
                return low;
        }
全部评论

相关推荐

牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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