Cet article vous présentera comment les novices peuvent apprendre le tri à bulles JAVA. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.
Bubble Sort est un algorithme de tri relativement simple dans le domaine de l'informatique.
Il visite à plusieurs reprises les éléments qui doivent être triés, compare tour à tour deux éléments adjacents et échange les positions des éléments si l'ordre des éléments (par exemple du grand au petit, première lettre de A à Z) est faux.
La visite des éléments est répétée jusqu'à ce qu'il n'y ait plus d'éléments adjacents à échanger et que le tri soit terminé.
Le nom de cet algorithme vient du fait que les éléments plus gros « flotteront » lentement vers le haut du tableau par échange (disposés par ordre croissant ou décroissant), tout comme les bulles de dioxyde de carbone dans les boissons gazeuses finiront par flotter vers en haut, d'où le nom "Tri à bulles".
Cela peut être un peu déroutant rien qu'en regardant la théorie, mais cela n'a pas d'importance. Ensuite, apprenons en détail comment le tri des bulles se compare et comment il est trié ~
Idées de tri<.>
Comparaison adjacente, trier de petit à grand, si plus petit, avancerI représente la traversée des données cycliques du début à la fin
implémenter le tri à bulles
package cn.tedu.array;import java.util.Arrays;/**本类用来完成Les débutants apprennent à trier les bulles JAVA*/public class TestBubbleSort { public static void main(String[] args) { //1.创建一个无序的数组 int[] a = {27,96,73,25,21}; //2.调用method()完成排序 int[] newA = method(a); System.out.println("排序完毕:"+Arrays.toString(newA)); } public static int[] method(int[] a) { //1.外层循环,控制比较的轮数,假设有n个数,最多比较n-1次 //开始值:1 结束值:<= a.length-1 变化:++ //控制的是循环执行的次数,比如5个数,最多比较4轮,<= a.length-1,最多取到4,也就是[1,4]4次 for(int i = 1 ; i <= a.length-1 ; i++) { System.out.println("第"+i+"轮:"); //2.内层循环:相邻比较+互换位置 for(int j=0; j < a.length-i ; j++) { //相邻比较,a[j]代表的就是前一个元素,a[j+1]代表的就是后一个元素 if(a[j] > a[j+1]) { //交换数据 int t = a[j]; a[j] = a[j+1]; a[j+1] = t; //System.out.println("第"+(j+1)+"次比较交换后:"+Arrays.toString(a)); } } System.out.println("第"+i+"轮的结果:"+Arrays.toString(a)); } return a;//把排序好的数组a返回 }}En fait, on peut aussi optimiser le tri existant :
Optimisation 1 : La valeur maximale générée lors des tours de tri précédents ne pas besoin d'être impliqué dans le post-traitement Après plusieurs tours de comparaison, plusieurs valeurs seront générées et il n'est pas nécessaire de participer à la comparaison. Le tour i produit des valeurs i, il est donc nécessaire - i
.
Recommandations d'apprentissage gratuites associées : Tutoriel de base Java
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Dreamweaver CS6
Outils de développement Web visuel

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP