All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.epam.deltix.util.collections.BinarySearch2 Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2021 EPAM Systems, Inc
 *
 * See the NOTICE file distributed with this work for additional information
 * regarding copyright ownership. Licensed under the Apache License,
 * Version 2.0 (the "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.epam.deltix.util.collections;

import java.util.Comparator;
import java.util.List;
import javax.swing.ListModel;

/**
 *
 */
public class BinarySearch2 {
    public static  int            binarySearch (
        List                   list,
        B                                   key,
        Comparator2   c
    )
    {
        int         low = 0;
        int         high = list.size () - 1;

        while (low <= high) {
            int     mid = (low + high) >>> 1;
            A       midVal = list.get(mid);
            int     cmp = c.compare (midVal, key);

            if (cmp < 0)
                low = mid + 1;
            else if (cmp > 0)
                high = mid - 1;
            else
                return mid; // key found
        }

        return -(low + 1);  // key not found
    }

    public static  int            binarySearch (
        A []                                arr,
        B                                   key,
        Comparator2   c
    )
    {
        return (binarySearch (arr, 0, arr.length, key, c));
    }

    public static  int            binarySearch (
        A []                                arr,
        int                                 offset,
        int                                 length,
        B                                   key,
        Comparator2   c
    )
    {
        int         low = offset;
        int         high = offset + length - 1;

        while (low <= high) {
            int     mid = (low + high) >>> 1;
            A       midVal = arr [mid];
            int     cmp = c.compare (midVal, key);

            if (cmp < 0)
                low = mid + 1;
            else if (cmp > 0)
                high = mid - 1;
            else
                return mid; // key found
        }

        return -(low + 1);  // key not found
    }

    public static  int            binarySearch (
        A []                                arr,
        int                                 offset,
        int                                 length,
        A                                   key,
        Comparator               c
    )
    {
        int         low = offset;
        int         high = offset + length - 1;

        while (low <= high) {
            int     mid = (low + high) >>> 1;
            A       midVal = arr [mid];
            int     cmp = c.compare (midVal, key);

            if (cmp < 0)
                low = mid + 1;
            else if (cmp > 0)
                high = mid - 1;
            else
                return mid; // key found
        }

        return -(low + 1);  // key not found
    }

    @SuppressWarnings ("unchecked")
    public static  int               binarySearch (
        ListModel                           model,
        int                                 offset,
        int                                 length,
        A                                   key,
        Comparator                       c
    )
    {
        int         low = offset;
        int         high = offset + length - 1;

        while (low <= high) {
            int     mid = (low + high) >>> 1;
            A       midVal = (A) model.getElementAt (mid);
            int     cmp = c.compare (midVal, key);

            if (cmp < 0)
                low = mid + 1;
            else if (cmp > 0)
                high = mid - 1;
            else
                return mid; // key found
        }

        return -(low + 1);  // key not found
    }

    @SuppressWarnings ("unchecked")
    public static  int            binarySearch (
        ListModel                           model,
        int                                 offset,
        int                                 length,
        B                                   key,
        Comparator2                    c
    )
    {
        int         low = offset;
        int         high = offset + length - 1;

        while (low <= high) {
            int     mid = (low + high) >>> 1;
            A       midVal = (A) model.getElementAt (mid);
            int     cmp = c.compare (midVal, key);

            if (cmp < 0)
                low = mid + 1;
            else if (cmp > 0)
                high = mid - 1;
            else
                return mid; // key found
        }

        return -(low + 1);  // key not found
    }
    
    public static int                   binarySearch (
        int []                              arr,
        int                                 offset,
        int                                 length,
        int                                 key
    )
    {
        int         low = offset;
        int         high = offset + length - 1;

        while (low <= high) {
            int     mid = (low + high) >>> 1;
            int     midVal = arr [mid];
            
            if (midVal < key)
                low = mid + 1;
            else if (midVal > key)
                high = mid - 1;
            else
                return mid; // key found
        }

        return -(low + 1);  // key not found
    }

    
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy