Home Java javaTutorial Methods and principles of writing insertion sort algorithm in Java

Methods and principles of writing insertion sort algorithm in Java

Feb 25, 2024 pm 04:54 PM
java language insertion sort algorithm Steps and ideas

Methods and principles of writing insertion sort algorithm in Java

The steps and ideas of the insertion sort algorithm

Insertion sort is a simple and intuitive sorting algorithm. Its basic idea is to insert the elements to be sorted into the sorted at the appropriate position in the sequence.

The specific steps are as follows:

  1. First, we divide the array into two parts: the sorted part and the unsorted part. Initially, there is only one element in the sorted part, which is the first element of the array.
  2. We take out an element from the unsorted part in turn, compare it with the elements in the sorted part one by one, and find the appropriate position to insert.
  3. During the comparison process, we move the elements in the sorted part backward to make room for the inserted elements.
  4. Finally, we insert all the elements of the unsorted part into the appropriate positions of the sorted part, and the sorting is completed.

The following is a sample code for writing the insertion sort algorithm in Java language:

public class InsertionSort {
    public static void insertionSort(int[] arr) {
        int n = arr.length;
        for (int i = 1; i < n; i++) {
            int key = arr[i];
            int j = i - 1;
            while (j >= 0 && arr[j] > key) {
                arr[j + 1] = arr[j];
                j--;
            }
            arr[j + 1] = key;
        }
    }

    public static void main(String[] args) {
        int[] arr = {5, 2, 8, 1, 9, 3};
        System.out.println("原数组:");
        printArray(arr);
        insertionSort(arr);
        System.out.println("排序后的数组:");
        printArray(arr);
    }

    public static void printArray(int[] arr) {
        int n = arr.length;
        for (int i = 0; i < n; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }
}
Copy after login

In this code example, we define an insertionSort method, which accepts An array of integers is taken as argument and the array is inserted sorted. We use n to represent the length of the array, and use for to loop through the elements of the unsorted part. In each traversal, we save the current element arr[i] to the key variable, and then traverse the sorted part forward to find the appropriate position to insert key. During the comparison process, we move the larger element back one position to make room for key. Finally, we insert key into the correct position and the sorting is completed.

In the main method, we initialize an integer array arr and call the insertionSort method to sort the array. Finally, we call the printArray method to print the sorted array.

By running the above code, you can get the following output:

原数组:
5 2 8 1 9 3 
排序后的数组:
1 2 3 5 8 9 
Copy after login

The time complexity of the insertion sort algorithm is O(n^2), where n is the length of the array. Although the insertion sort algorithm has a high time complexity, its implementation is simple and suitable for small-scale array sorting. At the same time, in practical applications, the insertion sort algorithm also has the characteristics of stability.

The above is the detailed content of Methods and principles of writing insertion sort algorithm in Java. For more information, please follow other related articles on the PHP Chinese website!

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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Introduction to smart agriculture application development in Java language Introduction to smart agriculture application development in Java language Jun 10, 2023 am 11:21 AM

With the development of the times, the agricultural field has also begun to upgrade and transform with the help of modern scientific and technological means, and smart agriculture has emerged as the times require. As a computer programming language with excellent performance and strong portability, Java has high popularity and application value, and has become one of the important solutions for smart agricultural application development. This article aims to introduce the development process, application scenarios and advantages of smart agricultural applications in Java language. 1. Development process of smart agricultural applications in Java language. The development process of smart agricultural applications is divided into requirements analysis,

How to convert JSON array to CSV in Java? How to convert JSON array to CSV in Java? Aug 21, 2023 pm 08:27 PM

JSON can be used as a data exchange format, it is lightweight and language independent. A JSONArray can parse text strings to produce vector-like objects and supports the java.util.List interface. We can convert JSON array to CSV format using org.json.CDL class, which provides a static method toString() for converting JSONArray to comma-separated text. We need to import the org.apache.commons.io.FileUtils package to store data in a CSV file using the writeStringToFile() method. Syntaxpublicstaticj

ChatGPT Java: How to build an accurate semantic search engine ChatGPT Java: How to build an accurate semantic search engine Oct 24, 2023 am 10:21 AM

ChatGPTJava: How to build an accurate semantic search engine, requiring specific code examples. Introduction: With the rapid development of the Internet and the explosive growth of information, people often encounter poor quality and inconsistent search results in the process of obtaining the required information. Exact question. In order to provide more accurate and efficient search results, semantic search engines came into being. This article will introduce how to use ChatGPTJava to build an accurate semantic search engine and give specific code examples. 1. Understanding ChatGPTJ

Introduction to image processing algorithms in Java language Introduction to image processing algorithms in Java language Jun 10, 2023 pm 10:03 PM

Introduction to image processing algorithms in Java language With the advent of the digital age, image processing has become an important branch of computer science. In computers, images are stored in digital form, and image processing changes the quality and appearance of the image by performing a series of algorithmic operations on these numbers. As a cross-platform programming language, Java language has rich image processing libraries and powerful algorithm support, making it the first choice of many developers. This article will introduce commonly used image processing algorithms in the Java language, and

Detailed explanation of binary tree structure in Java Detailed explanation of binary tree structure in Java Jun 16, 2023 am 08:58 AM

Binary trees are a common data structure in computer science and a commonly used data structure in Java programming. This article will introduce the binary tree structure in Java in detail. 1. What is a binary tree? In computer science, a binary tree is a tree structure in which each node has at most two child nodes. Among them, the left child node is smaller than the parent node, and the right child node is larger than the parent node. In Java programming, binary trees are commonly used to represent sorting, searching and improving the efficiency of data query. 2. Binary tree implementation in Java In Java, binary tree

Introduction to financial application development in Java language Introduction to financial application development in Java language Jun 10, 2023 pm 02:01 PM

Java language is a programming language widely used in the financial field. Due to its powerful functions and efficient performance, Java language has become the preferred language for financial institutions to develop software. This article will introduce the importance of Java language in financial application development and introduce some common financial applications. 1. Application of Java language in the financial field Java language has been widely used in the financial field. Its main advantages include: 1. Cross-platform capability. The Java language has cross-platform capability, which means that the same Java language

Methods and steps for implementing image style migration by connecting to Baidu AI interface in Java language Methods and steps for implementing image style migration by connecting to Baidu AI interface in Java language Aug 12, 2023 pm 04:00 PM

Methods and steps for implementing image style transfer by connecting to Baidu AI interface in Java language Introduction: Image style transfer is an interesting technology that has wide applications in art and media creation. Baidu AI provides an API for image style migration, allowing developers to easily use this function. This article will introduce how to use Java language to connect to Baidu AI interface, implement methods and steps for image style migration, and provide sample code. Step 1: To apply for access to Baidu AI interface, you must use the image style migration AP provided by Baidu AI.

Introduction to Spring Cloud framework in Java language Introduction to Spring Cloud framework in Java language Jun 09, 2023 pm 10:54 PM

Introduction to the Spring Cloud framework in the Java language With the popularity of cloud computing and microservices, the Spring Cloud framework has become one of the preferred frameworks for building cloud native applications in the Java language. This article will introduce the concepts and features of the Spring Cloud framework, and how to use Spring Cloud to build a microservice architecture. Introduction to SpringCloud The SpringCloud framework is a microservice framework based on SpringBoot. it is

See all articles