Home > Java > javaTutorial > How to implement half insertion sort algorithm in Java

How to implement half insertion sort algorithm in Java

王林
Release: 2023-04-29 19:52:04
forward
959 people have browsed it

    Introduction to sorting algorithm

    The sorting algorithm uses a specific algorithm factor to process one or more sets of data according to an established pattern. rearrange. The final sequence is presented according to certain rules.

    In sorting algorithms, stability and efficiency are issues we often have to consider.

    Stability: Stability means that when two identical elements appear in a sequence at the same time, after a certain sorting algorithm, the relative positions of the two before and after sorting do not change.

    Complexity analysis:

    (1) Time complexity: that is, the process from the initial state of the sequence to the final sorted result state after operations such as transformation and shifting of the sorting algorithm. A measure of time spent.

    (2) Space complexity: It is the space overhead spent from the initial state of the sequence through the process of sorting and shift transformation to the final state.

    Common sorting algorithms are divided into the following types:

    How to implement half insertion sort algorithm in Java

    halved insertion sort

    Principle

    halved insertion sort (Binary Insertion Sort) is an improvement on the insertion sort algorithm. Continuously insert elements into the previously sorted sequence. Since the first half is a sorted sequence, we don't have to search for the insertion point in sequence. We can use the half search method to speed up the search for the insertion point.

    Code implementation

    In the process of inserting a new element into the sorted array, when looking for the insertion point, set the first element of the area to be inserted to a[low], and the last element If the element is set to a[high], then in each round of comparison, the element to be inserted will be compared with a[m], where m = (low high)/2. If it is smaller than the reference element, select a[low] to a[ m-1] is the new insertion area (i.e. high=m-1), otherwise select a[m 1] to a[high] as the new insertion area (i.e. low=m 1), and so on until low

    In short: take advantage of the ordering characteristics of the arranged elements and use the characteristics of half search to quickly find the position to be inserted.

        // Binary Insertion Sort method    
        private static void binaryInsertSort(int[] array){
           
            for(int i = 1; i < array.length; i++){
               
                int temp = array[i];            
                int low = 0;            
                int high = i - 1;  
               
                while(low <= high){                
                    int mid = (low + high) / 2;                
                    if(temp < array[mid]){                    
                        high = mid - 1;                
                    }else{                    
                        low = mid + 1;
                    }       
                }
               
                for(int j = i; j >= low + 1; j--){            
                    array[j] = array[j - 1];                                                      
                }       
               
                array[low] = temp;       
            }   
        }
    Copy after login

    Complexity Analysis

    The half insertion sort algorithm is a stable sorting algorithm. It significantly reduces the number of comparisons between keywords compared to the direct insertion algorithm, so it is faster than the direct insertion sort algorithm. Fast, but the number of record moves has not changed, so the time complexity of the halved insertion sort algorithm is still O(n^2), which is the same as the direct insertion sort algorithm.

    Time complexity

    Best case: O(n). If the elements are sorted in forward order, the position will be found directly at the beginning, without searching and shifting.

    Worst case: O(n^2). If the elements are sorted in reverse order, a data lookup is required every time.

    Average complexity: O(n^2).

    Space complexity: O(1). Only a few storage spaces are needed to record the key units of information, that is, the space complexity is O(1).

    Example:

    How to implement half insertion sort algorithm in Java

    Algorithm practice

    The overall idea of ​​the algorithm has been described above. Let’s use an example to test the water directly. .

    Half insertion sort

    Problem description:

    I give you an integer array nums, please sort the array in ascending order.

    Example 1:

    Input: nums = [5,2,3,1]

    Output: [1,2,3,5]

    Example 2:

    Input: nums = [5,1,1,2,0,0]

    Output: [0,0,1,1,2,5]

    Tips:

    1 <= nums.length <= 5 * 104

    -5 * 104 <= nums[i] <= 5 * 104

    class Solution {
        public int[] sortArray(int[] nums) {
            for(int i = 1; i < nums.length; i++){
               
                int temp = nums[i];            
                int low = 0;            
                int high = i - 1;  
               
                while(low <= high){                
                    int mid = (low + high) / 2;                
                    if(temp < nums[mid]){                    
                        high = mid - 1;                
                    }else{                    
                        low = mid + 1;
                    }       
                }
               
                for(int j = i; j >= low + 1; j--){            
                    nums[j] = nums[j - 1];                                                      
                }       
               
                nums[low] = temp;       
            }   
            return nums;
        }
    }
    Copy after login

    The above is the detailed content of How to implement half insertion sort algorithm in Java. For more information, please follow other related articles on the PHP Chinese website!

    Related labels:
    source:yisu.com
    Statement of this Website
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
    Popular Tutorials
    More>
    Latest Downloads
    More>
    Web Effects
    Website Source Code
    Website Materials
    Front End Template