Table des matières
Table de hachage
Concurrententretien java - structure des données
Linkedentretien java - structure des données, TreeMap, TreeSet
ArrayList, LinkedList, Vector
Collection et collections
Arbre binaire
Concepts courants d'arbre binaire
Parcours d'arbre binaire
Maison Java JavaQuestions d'entretien entretien java - structure des données

entretien java - structure des données

Nov 25, 2020 pm 03:57 PM
java 数据结构 面试

entretien java - structure des données

Les structures de données courantes incluent : entretien java - structure des données, Hashtable, Concurrententretien java - structure des données.

(Partage de vidéos associées : vidéo d'enseignement Java)

Présentons-les séparément :

entretien java - structure des données

  • Implémentation sous-jacente : la structure globale sous-jacente de entretien java - structure des données est un tableau, et chaque élément du tableau est une liste chaînée. Chaque fois qu'un objet (put) est ajouté, un objet de liste chaînée (type d'objet) sera généré. Chaque entrée dans la carte est un élément du tableau (Map.Entry est un <key></key>), qui pointe vers l'élément actuel. au suivant Les références aux éléments forment une liste chaînée.
  • Principe de stockage : lors de l'ajout d'un élément à HsahMap, calculez d'abord la valeur de hachage de l'objet Key et récupérez l'indice du tableau. Si la position dans le tableau est vide, insérez-la, sinon parcourez la liste chaînée à cet endroit. position. Lorsque l'objet Key et l'objet Node d'un nœud sont égaux au nouvel élément, remplacez l'objet Value du nœud par l'objet Value du nouvel élément, sinon insérez un nouveau nœud. (Remarque : Des arbres rouge-noir ont été ajoutés après JDK 8)

La longueur de entretien java - structure des données est de 2 élevée à la nième puissance afin de rendre tous les bits du la valeur binaire de length-1 complete est 1. Dans ce cas, lorsque la valeur de hachage et (table.length - 1) effectuent une opération & pour calculer l'index, le résultat est équivalent à la valeur des derniers chiffres du hashcode. À ce stade, tant que le hashcode d'entrée lui-même est distribué uniformément, l'algorithme de hachage Le résultat est l'uniformité. Par conséquent, la longueur par défaut de entretien java - structure des données est de 16 pour réduire la probabilité de collision de hachage, et c'est également une taille appropriée.

entretien java - structure des données

Table de hachage

比较点 entretien java - structure des données Hashtable
实现原理 见上小节 和entretien java - structure des données的实现原理几乎一样
Key和Value 允许Key和Value为null 不允许Key和Value为null
扩容策略 2倍扩容oldThr 2倍+1扩容(oldCapacity
安全性 线程不安全 线程安全

La stratégie de sécurité des threads de la table de hachage est très coûteuse à mettre en œuvre. Toutes les opérations get/put associées sont synchronisées et les performances sont très médiocres dans des scénarios de concurrence hautement compétitifs.

Concurrententretien java - structure des données

Concurrententretien java - structure des données est une implémentation entretien java - structure des données thread-safe et efficace fournie dans le package de concurrence Java. Elle adopte une stratégie de verrouillage de segmentation très exquise. de Concurrententretien java - structure des données est le tableau Segment. Le segment hérite de ReentrantLock et est un verrou réentrant. Chaque segment est une sous-table de hachage et un tableau HashEntry est conservé dans le segment. Dans un environnement simultané, il n'est pas nécessaire de prendre en compte la concurrence des verrous lors de l'exploitation des données de différents segments.

Concurrententretien java - structure des données

Linkedentretien java - structure des données, TreeMap, TreeSet

  • Linkedentretien java - structure des données : entretien java - structure des données à accès séquentiel (implémenté sur la base de tableaux et de listes doublement chaînées).
  • TreeMap : tri interne (basé sur l'implémentation d'un arbre rouge-noir).
  • TreeSet : une collection Set ordonnée (basée sur l'implémentation d'un arbre binaire).

ArrayList, LinkedList, Vector

  • ArrayList : tableau dynamique (basé sur l'implémentation du tableau).
  • LinkedList : tableau ordonné (implémenté sur la base d'une liste doublement chaînée).
  • Vector : Conteneur d'objets, qui peut mettre des objets de différents types (implémentés en fonction de tableaux).

Collection et collections

  • Collection : L'interface supérieure de la classe collection, les sous-interfaces incluent principalement List, Set, Queue, etc.
  • Collections : fournit des classes d'outils pour les opérations de recherche, de tri, de remplacement et de sécurité des threads sur les collections.

(Recommandations pour des questions d'entretien plus connexes : questions et réponses d'entretien Java)

Arbre binaire

Concepts courants d'arbre binaire

  • Arbre B+ : voir section base de donnéeshttps://blog.csdn.net/u012102104/article/details/79773362

  • Arbre binaire équilibré (arbre AVL) : la valeur absolue de la différence de profondeur entre les sous-arbres gauche et droit de chaque nœud ne dépasse pas 1.

  • Arbre de Huffman : L'arbre binaire avec la plus petite longueur de chemin pondérée est appelé l'arbre binaire optimal. La construction de l’arbre de Huffman n’est pas unique, mais la somme des longueurs de chemin pondérées de tous les nœuds feuilles est la plus petite.

  • Arbre rouge-noir : un arbre de recherche binaire auto-équilibré, ses propriétés sont :

    1. Les nœuds sont rouges ou noirs.
    2. Le nœud racine est noir.
    3. Chaque nœud feuille est un nœud noir vide (nœud NIL).
    4. Les deux nœuds enfants de chaque nœud rouge sont noirs.
    5. Tous les chemins d'un nœud à chacune de ses feuilles contiennent le même nombre de nœuds noirs.

    Il ne peut pas y avoir deux nœuds rouges consécutifs sur tous les chemins de chaque feuille à la racine

Parcours d'arbre binaire

// 1. 先序遍历算法 DLRvoid Preorder ( BinTree bt ) {
	if ( bt ) {
		visit ( bt->data );
		Preorder ( bt->lchild );
		Preorder ( bt->rchild );
	}}// 2. 中序遍历算法 LDRvoid Inorder ( BinTree bt ) {
	if ( bt ) {
		Inorder ( bt->lchild );
		visit ( bt->data );
		Inorder ( bt->rchild );
	}}// 3. 后序遍历 LRDvoid Postorder ( BinTree bt ) {
	if ( bt ) {
		Postorder ( bt->lchild );
		Postorder ( bt->rchild );
		visit ( bt->data );
	}}// 4. 按层次遍历。/* 思路:利用一个队列,首先将根(头指针)入队列,以后若队列不空则取队头元素 p,
如果 p 不空,则访问之,然后将其左右子树入队列,如此循环直到队列为空。*/void LevelOrder ( BinTree bt ) {
	// 队列初始化为空
	InitQueue ( Q );
	// 根入队列
	EnQueue ( Q, bt );
	// 队列不空则继续遍历
	while ( ! QueueEmpty(Q) ) {
		DeQueue ( Q, p );
		if ( p!=NULL ) {
			visit ( p->data );
			// 左、右子树入队列
			EnQueue ( Q, p->lchild );
			EnQueue ( Q, p->rchild );
		}
	}}// 非递归遍历二叉树一般借助栈实现
Copier après la connexion

Recommandations associées : Tutoriel d'introduction à 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 de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

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.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Nombre parfait en Java Nombre parfait en Java Aug 30, 2024 pm 04:28 PM

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Weka en Java Weka en Java Aug 30, 2024 pm 04:28 PM

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Numéro de Smith en Java Numéro de Smith en Java Aug 30, 2024 pm 04:28 PM

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Questions d'entretien chez Java Spring Questions d'entretien chez Java Spring Aug 30, 2024 pm 04:29 PM

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Break or Return of Java 8 Stream Forach? Break or Return of Java 8 Stream Forach? Feb 07, 2025 pm 12:09 PM

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Horodatage à ce jour en Java Horodatage à ce jour en Java Aug 30, 2024 pm 04:28 PM

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Créer l'avenir : programmation Java pour les débutants absolus Créer l'avenir : programmation Java pour les débutants absolus Oct 13, 2024 pm 01:32 PM

Java est un langage de programmation populaire qui peut être appris aussi bien par les développeurs débutants que par les développeurs expérimentés. Ce didacticiel commence par les concepts de base et progresse vers des sujets avancés. Après avoir installé le kit de développement Java, vous pouvez vous entraîner à la programmation en créant un simple programme « Hello, World ! ». Une fois que vous avez compris le code, utilisez l'invite de commande pour compiler et exécuter le programme, et « Hello, World ! » s'affichera sur la console. L'apprentissage de Java commence votre parcours de programmation et, à mesure que votre maîtrise s'approfondit, vous pouvez créer des applications plus complexes.

Programme Java pour trouver le volume de la capsule Programme Java pour trouver le volume de la capsule Feb 07, 2025 am 11:37 AM

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

See all articles