Maison >interface Web >js tutoriel >Gestion des données en streaming avec des tas Min et Max en JavaScript : une perspective de technologie de santé des athlètes numériques
La gestion des données est cruciale dans les technologies de la santé. Qu'il s'agisse de suivre des mesures de performance ou de surveiller les temps de récupération des athlètes, l'organisation efficace des données peut faire une différence significative dans la façon dont les informations sont obtenues. Un outil puissant pour gérer les données dans de tels scénarios est le tas, en particulier les tas min et max. Dans cet article, nous explorerons comment implémenter et utiliser les tas min et max en JavaScript, à l'aide d'exemples concrets liés à la gestion des données des athlètes.
Un tas est une structure de données spécialisée basée sur un arbre binaire qui satisfait à la propriété du tas. Dans un min tas, le nœud parent est toujours plus petit ou égal à ses nœuds enfants. A l’inverse, dans un max tas, le nœud parent est toujours supérieur ou égal à ses nœuds enfants. Cela rend les tas particulièrement utiles pour récupérer efficacement la valeur minimale ou maximale d'un ensemble de données.
Imaginez que vous êtes un clinicien qui suit les temps de récupération des athlètes après une séance d'entraînement. Vous souhaitez suivre efficacement le temps de récupération le plus court afin de pouvoir identifier rapidement quel athlète a récupéré le plus rapidement.
En JavaScript, vous pouvez créer un tas min à l'aide d'un tableau et le gérer avec des fonctions simples pour conserver la propriété du tas :
class MinHeap { constructor() { this.heap = []; } getMin() { return this.heap[0]; } insert(value) { this.heap.push(value); this.bubbleUp(); } bubbleUp() { let index = this.heap.length - 1; while (index > 0) { let parentIndex = Math.floor((index - 1) / 2); if (this.heap[parentIndex] <= this.heap[index]) break; [this.heap[parentIndex], this.heap[index]] = [this.heap[index], this.heap[parentIndex]]; index = parentIndex; } } extractMin() { if (this.heap.length === 1) return this.heap.pop(); const min = this.heap[0]; this.heap[0] = this.heap.pop(); this.bubbleDown(); return min; } bubbleDown() { let index = 0; const length = this.heap.length; const element = this.heap[0]; while (true) { let leftChildIndex = 2 * index + 1; let rightChildIndex = 2 * index + 2; let leftChild, rightChild; let swap = null; if (leftChildIndex < length) { leftChild = this.heap[leftChildIndex]; if (leftChild < element) swap = leftChildIndex; } if (rightChildIndex < length) { rightChild = this.heap[rightChildIndex]; if ( (swap === null && rightChild < element) || (swap !== null && rightChild < leftChild) ) { swap = rightChildIndex; } } if (swap === null) break; [this.heap[index], this.heap[swap]] = [this.heap[swap], this.heap[index]]; index = swap; } } }
Maintenant, appliquons ceci à notre scénario :
const recoveryTimes = new MinHeap(); recoveryTimes.insert(10); // Athlete A recoveryTimes.insert(7); // Athlete B recoveryTimes.insert(12); // Athlete C console.log("Fastest recovery time:", recoveryTimes.getMin()); // Outputs: 7
Ici, le tas min permet au clinicien d'identifier rapidement l'athlète avec le temps de récupération le plus rapide, ce qui est essentiel pour prendre des décisions en temps réel lors d'une séance d'entraînement.
D'un autre côté, un tas maximum est idéal pour les scénarios dans lesquels vous devez suivre les valeurs les plus élevées, comme la surveillance de mesures de performances maximales telles que la fréquence cardiaque maximale atteinte lors d'un entraînement intense.
Un tas max peut être implémenté de la même manière qu'un tas min, avec quelques ajustements :
class MaxHeap { constructor() { this.heap = []; } getMax() { return this.heap[0]; } insert(value) { this.heap.push(value); this.bubbleUp(); } bubbleUp() { let index = this.heap.length - 1; while (index > 0) { let parentIndex = Math.floor((index - 1) / 2); if (this.heap[parentIndex] >= this.heap[index]) break; [this.heap[parentIndex], this.heap[index]] = [this.heap[index], this.heap[parentIndex]]; index = parentIndex; } } extractMax() { if (this.heap.length === 1) return this.heap.pop(); const max = this.heap[0]; this.heap[0] = this.heap.pop(); this.bubbleDown(); return max; } bubbleDown() { let index = 0; const length = this.heap.length; const element = this.heap[0]; while (true) { let leftChildIndex = 2 * index + 1; let rightChildIndex = 2 * index + 2; let leftChild, rightChild; let swap = null; if (leftChildIndex < length) { leftChild = this.heap[leftChildIndex]; if (leftChild > element) swap = leftChildIndex; } if (rightChildIndex < length) { rightChild = this.heap[rightChildIndex]; if ( (swap === null && rightChild > element) || (swap !== null && rightChild > leftChild) ) { swap = rightChildIndex; } } if (swap === null) break; [this.heap[index], this.heap[swap]] = [this.heap[swap], this.heap[index]]; index = swap; } } }
Voyons comment un tas maximum pourrait être utilisé pour suivre la fréquence cardiaque maximale des athlètes pendant une séance d'entraînement :
const heartRates = new MaxHeap(); heartRates.insert(150); // Athlete A heartRates.insert(165); // Athlete B heartRates.insert(160); // Athlete C console.log("Peak heart rate:", heartRates.getMax()); // Outputs: 165
Ici, le tas maximum garantit que le clinicien peut identifier rapidement l'athlète qui a atteint la fréquence cardiaque la plus élevée, ce qui pourrait signaler qu'une attention supplémentaire ou un temps de récupération est nécessaire.
En plus d'insérer des éléments et de récupérer les valeurs min ou max, les tas prennent en charge d'autres opérations de base, telles que :
Ces opérations sont essentielles pour gérer et traiter efficacement les données en temps réel, faisant des tas un outil précieux dans les applications de technologie de la santé.
En Python, le module heapq fournit un moyen simple et efficace de gérer les tas min à l'aide de listes. Voici un exemple :
import heapq # Create an empty list to represent the heap recovery_times = [] # Add elements to the heap heapq.heappush(recovery_times, 10) # Athlete A heapq.heappush(recovery_times, 7) # Athlete B heapq.heappush(recovery_times, 12) # Athlete C # Retrieve the smallest element (fastest recovery time) fastest_recovery_time = heapq.heappop(recovery_times) print(f"Fastest recovery time: {fastest_recovery_time}") # Outputs: 7
Pour JavaScript, bien qu'il n'y ait pas de module de tas intégré, vous pouvez utiliser des bibliothèques tierces comme @datastructures-js/priority-queue pour obtenir des fonctionnalités similaires :
// First, you would need to install the @datastructures-js/priority-queue library using npm: // npm install @datastructures-js/priority-queue const { MinPriorityQueue } = require('@datastructures-js/priority-queue'); // Create a new min heap const minHeap = new MinPriorityQueue(); // Add elements to the heap minHeap.enqueue(10); // Athlete A minHeap.enqueue(7); // Athlete B minHeap.enqueue(12); // Athlete C // Retrieve the smallest element const fastestRecoveryTime = minHeap.dequeue().element; console.log("Fastest recovery time:", fastestRecoveryTime); // Outputs: 7
En tirant parti de ces outils, vous pouvez vous concentrer sur les aspects critiques de votre application, tels que l'analyse des données des athlètes, sans vous enliser dans les détails de la mise en œuvre du tas.
Les tas, en particulier les tas min et max, sont des outils puissants pour gérer et récupérer efficacement les données critiques en JavaScript. Qu'il s'agisse de suivre les temps de récupération ou de surveiller les mesures de performances maximales, ces structures aident les cliniciens et les professionnels des technologies de la santé à prendre rapidement des décisions éclairées. En comprenant et en mettant en œuvre des tas, vous pouvez vous assurer que les données de vos athlètes sont organisées, accessibles et prêtes à être analysées lorsque cela compte le plus.
En utilisant des tas dans vos applications de technologie de santé, vous serez en mesure de gérer les données de manière à favoriser de meilleurs résultats pour les athlètes, en fournissant les informations nécessaires pour optimiser les performances et la récupération.
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!