recherche
MaisonJavajavaDidacticielLes débutants apprennent à trier les bulles JAVA

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.

Les débutants apprennent à trier les bulles JAVA

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, avancer

I représente la traversée des données cycliques du début à la fin

Les débutants apprennent à trier les bulles JAVAimplémenter le tri à bulles

Créer une classe : BubbleSort.java

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
.

Optimisation 2 : Nous devons définir une quantité qui est utilisée. Vérifiez s'il y a eu un échange d'éléments dans le cycle de comparaison mutuelle en cours. Si un échange a eu lieu, cela signifie que la commande n'a pas été organisée. flag sera changé en true et le prochain tour de comparaison sera effectué. Mais si dans le tour en cours, tous les éléments ont été comparés les uns aux autres et n'ont pas échangé leurs positions, ce qui signifie que l'ordre a été trié. besoin du prochain cycle de comparaison, renvoyez simplement la méthode de fin directement


Les débutants apprennent à trier les bulles JAVA

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!

Déclaration
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Outils chauds

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

MinGW - GNU minimaliste pour Windows

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

Dreamweaver CS6

Outils de développement Web visuel

mPDF

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

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP