Rumah hujung hadapan web tutorial js Menguruskan Data Penstriman dengan Min dan Max Heaps dalam JavaScript: Perspektif Teknologi Kesihatan Atlet Digital

Menguruskan Data Penstriman dengan Min dan Max Heaps dalam JavaScript: Perspektif Teknologi Kesihatan Atlet Digital

Aug 31, 2024 am 11:02 AM

Managing Streaming Data with Min and Max Heaps in JavaScript: A Digital Athlete Health Tech Perspective

Pengurusan data adalah penting dalam teknologi kesihatan. Sama ada menjejak metrik prestasi atau memantau masa pemulihan untuk atlet, menyusun data dengan cekap boleh membuat perbezaan yang ketara dalam cara cerapan diperoleh. Satu alat yang berkuasa untuk mengurus data dalam senario sedemikian ialah timbunan, khususnya timbunan min dan maks. Dalam siaran ini, kami akan meneroka cara untuk melaksanakan dan menggunakan timbunan min dan maks dalam JavaScript, menggunakan contoh dunia sebenar yang berkaitan dengan pengurusan data atlet.

Apakah Heaps?

Timbunan ialah struktur data berasaskan pokok binari khusus yang memenuhi sifat timbunan. Dalam timbunan min, nod induk sentiasa lebih kecil daripada atau sama dengan nod anaknya. Sebaliknya, dalam timbunan maks, nod induk sentiasa lebih besar daripada atau sama dengan nod anaknya. Ini menjadikan timbunan amat berguna untuk mendapatkan semula nilai minimum atau maksimum daripada set data dengan cekap.

Kes Penggunaan Timbunan Min: Menjejak Masa Pemulihan

Bayangkan anda seorang doktor yang menjejaki masa pemulihan atlet selepas bersenam. Anda ingin menjejaki masa pemulihan terpendek dengan cekap supaya anda boleh mengenal pasti atlet mana yang pulih paling cepat.

Mencipta Timbunan Min

Dalam JavaScript, anda boleh mencipta timbunan min menggunakan tatasusunan dan mengurusnya dengan fungsi mudah untuk mengekalkan sifat timbunan:

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;
        }
    }
}

Menggunakan Timbunan Min untuk Masa Pemulihan Atlet

Sekarang, mari gunakan ini pada senario kami:

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

Di sini, timbunan min membolehkan doktor mengenal pasti atlet dengan cepat dengan masa pemulihan terpantas, yang penting untuk membuat keputusan masa nyata semasa sesi latihan.

Kes Penggunaan Timbunan Maks: Memantau Metrik Prestasi Puncak

Sebaliknya, timbunan maks adalah sesuai untuk senario di mana anda perlu menjejaki nilai tertinggi, seperti memantau metrik prestasi puncak seperti kadar denyutan jantung maksimum yang dicapai semasa senaman yang sengit.

Mencipta Timbunan Maks

Timbunan maks boleh dilaksanakan sama seperti timbunan min, dengan beberapa pelarasan:

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;
        }
    }
}

Menggunakan Timbunan Maks untuk Kadar Jantung Puncak

Mari kita pertimbangkan cara timbunan maksimum boleh digunakan untuk menjejaki kadar denyutan jantung puncak atlet semasa bersenam:

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

Di sini, timbunan maksimum memastikan bahawa doktor dapat mengenal pasti dengan cepat atlet yang mencapai kadar denyutan jantung tertinggi, yang mungkin memberi isyarat bahawa perhatian atau penyejukan lanjut diperlukan.

Operasi Timbunan Asas Lain

Selain memasukkan elemen dan mendapatkan semula nilai min atau maks, timbunan menyokong operasi asas lain, seperti:

  • Mengekstrak min/maks: Ini mengalih keluar punca timbunan (elemen terkecil dalam timbunan min atau yang terbesar dalam timbunan maks) dan mengimbangi semula timbunan.
  • Heapify: Menukar tatasusunan arbitrari kepada timbunan, memastikan sifat timbunan dikekalkan.
  • Intai: Melihat nilai min atau maksimum tanpa mengalih keluarnya daripada timbunan.

Operasi ini penting untuk mengurus dan memproses data dengan cekap dalam masa nyata, menjadikan timbunan sebagai alat yang berharga dalam aplikasi teknologi kesihatan.

Memudahkan Operasi Timbunan dalam Python dan JavaScript

Dalam Python, modul heapq menyediakan cara yang mudah dan cekap untuk mengurus timbunan min menggunakan senarai. Berikut ialah contoh:

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

Untuk JavaScript, walaupun tidak ada modul timbunan terbina dalam, anda boleh menggunakan perpustakaan pihak ketiga seperti @datastructures-js/priority-queue untuk mencapai fungsi yang serupa:

// 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

Dengan memanfaatkan alatan ini, anda boleh menumpukan pada aspek kritikal aplikasi anda, seperti menganalisis data atlet, tanpa terperangkap dalam butiran pelaksanaan timbunan.

Mendapatkan semula data dengan cekap dalam JavaScript

Timbunan, terutamanya timbunan min dan maks, ialah alat yang berkuasa untuk mengurus dan mendapatkan semula data kritikal dengan cekap dalam JavaScript. Sama ada anda menjejak masa pemulihan atau memantau metrik prestasi puncak, struktur ini membantu doktor dan profesional teknologi kesihatan membuat keputusan termaklum dengan cepat. Dengan memahami dan melaksanakan timbunan, anda boleh memastikan bahawa data atlet anda teratur, boleh diakses dan sedia untuk dianalisis apabila ia paling penting.

Dengan menggunakan timbunan dalam aplikasi teknologi kesihatan anda, anda akan dapat mengendalikan data dengan cara yang menyokong hasil yang lebih baik untuk atlet, memberikan cerapan yang diperlukan untuk mengoptimumkan prestasi dan pemulihan.

Atas ialah kandungan terperinci Menguruskan Data Penstriman dengan Min dan Max Heaps dalam JavaScript: Perspektif Teknologi Kesihatan Atlet Digital. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana anda memilih elemen dengan atribut data dalam JavaScript? Bagaimana anda memilih elemen dengan atribut data dalam JavaScript? Aug 30, 2025 am 01:57 AM

Anda boleh memilih elemen dengan atribut data dalam JavaScript melalui pemilih atribut CSS, dan gunakan document.QuerySelector () atau document.QuerySelectorAll () kaedah untuk mencapai matlamat ini. 1. Gunakan [data-attribute] untuk memilih elemen dengan atribut data yang ditentukan (sebarang nilai); 2. Gunakan [data-attribute = "nilai"] untuk memilih elemen yang nilai atributnya sesuai; 3. Akses atribut data melalui elemen.dataset, di mana data-us-id sepadan dengan dataset.userid (ganti

Pytest dan Selenium: Strategi pelaksanaan untuk ujian yang didorong oleh data dinamik Pytest dan Selenium: Strategi pelaksanaan untuk ujian yang didorong oleh data dinamik Aug 30, 2025 am 06:00 AM

Artikel ini bertujuan untuk menyelesaikan masalah yang @pytest.mark.parametrize decorator tidak dapat secara langsung mengendalikan data yang dijana pada runtime apabila menggunakan pytest dan selenium untuk ujian yang didorong data dinamik. Kami akan meneroka batasan pytest.mark.parametrize secara mendalam, dan memperkenalkan secara terperinci bagaimana untuk melaksanakan ujian parameter secara anggun berdasarkan pemerolehan data dinamik selenium melalui Pytest's PYTest_Generate_Tests Hook berfungsi untuk memastikan fleksibiliti dan kecekapan kes ujian.

Mengoptimumkan pengendalian acara lompat luaran dinamik di tetingkap pop timbul jQuery Mengoptimumkan pengendalian acara lompat luaran dinamik di tetingkap pop timbul jQuery Sep 01, 2025 am 11:48 AM

Artikel ini bertujuan untuk menyelesaikan masalah mengalihkan butang redirect pautan luaran dalam tetingkap pop-up jQuery menyebabkan kesilapan lompat. Apabila pengguna mengklik pelbagai pautan luaran dalam penggantian, butang lompat di pop timbul mungkin selalu menunjuk pada pautan pertama yang diklik. Penyelesaian teras adalah dengan menggunakan kaedah off ('klik') untuk membatalkan pengendali acara lama sebelum setiap mengikat peristiwa baru, memastikan bahawa tingkah laku lompat sentiasa menunjuk kepada URL sasaran terkini, dengan itu mencapai pengalihan pautan yang tepat dan terkawal.

Bina kaunter JavaScript berjalan dengan hari bekerja dan waktu bekerja Bina kaunter JavaScript berjalan dengan hari bekerja dan waktu bekerja Aug 31, 2025 am 06:30 AM

Artikel ini memperincikan bagaimana untuk membina kaunter masa yang tepat menggunakan JavaScript. Kaunter itu bertambah sekali seminit, tetapi hanya berjalan dalam hari kerja pratetap (Isnin hingga Jumaat) dan jam kerja (seperti 6 pagi hingga 8 malam). Ia boleh menjeda kenaikan semasa waktu tidak bekerja tetapi memaparkan nilai semasa dan menetapkan semula secara automatik pada hari pertama setiap bulan, memastikan ketepatan dan fleksibiliti logik pengiraan.

Bagaimana unsur -unsur DOM yang dibuat secara dinamik diakses dan dikendalikan oleh skrip yang dimuatkan Bagaimana unsur -unsur DOM yang dibuat secara dinamik diakses dan dikendalikan oleh skrip yang dimuatkan Aug 30, 2025 am 11:57 AM

Artikel ini menerangkan bagaimana skrip JavaScript dapat diakses dengan berkesan dan dimanipulasi apabila ia dimuatkan dan dilaksanakan sebelum penciptaan elemen DOM dalam pembangunan web. Kami akan memperkenalkan tiga strategi teras: secara langsung lulus rujukan elemen melalui nilai pulangan fungsi, menggunakan peristiwa tersuai untuk mencapai komunikasi antara modul, dan menggunakan MutationObserver untuk mendengar perubahan struktur DOM. Kaedah ini dapat membantu pemaju menyelesaikan cabaran antara masa pelaksanaan JavaScript dan pemuatan kandungan dinamik, memastikan skrip dapat mengendalikan unsur-unsur dengan betul, seperti menjadikannya drag-mampu.

Evolusi JavaScript: Lihat ES2023 dan seterusnya Evolusi JavaScript: Lihat ES2023 dan seterusnya Aug 29, 2025 am 12:18 AM

ES2023 telah memperkenalkan beberapa kemas kini praktikal, menandakan evolusi matang JavaScript. 1.Array.Prototype.Findlast () dan findLastIndex () kaedah menyokong carian dari akhir array, meningkatkan kecekapan log pemprosesan atau konfigurasi; 2.Hashbang Syntax (#!/Usr/bin/envnode) membolehkan fail JavaScript dilaksanakan secara langsung dalam sistem seperti UNIX; 3.Ror.Cause menyokong rantaian ralat, meningkatkan keupayaan debugging pengecualian; 4. Spesifikasi lemah dan set meningkatkan konsistensi enjin; Pada masa akan datang, penghias (Stage3), Rekod dan Tuples (

JavaScript menyedari kesan penukaran imej klik: tutorial profesional JavaScript menyedari kesan penukaran imej klik: tutorial profesional Sep 18, 2025 pm 01:03 PM

Artikel ini akan memperkenalkan cara menggunakan JavaScript untuk mencapai kesan mengklik pada imej. Idea teras adalah menggunakan atribut data HTML5 untuk menyimpan laluan imej alternatif, dan mendengar klik acara melalui JavaScript, secara dinamik menukar atribut SRC, dengan itu menyedari penukaran imej. Artikel ini akan memberikan contoh dan penjelasan kod terperinci untuk membantu anda memahami dan menguasai kesan interaktif yang biasa digunakan ini.

Cara mengemas kini sifat objek dalam javascript Cara mengemas kini sifat objek dalam javascript Sep 04, 2025 am 04:58 AM

USEDOTNOTATIONTOUPDATEPROPERIESSWITHITEDNAMES; 2.USEBEBRACKETNOTATIONFORDYNAMICORSPECIALCHARACTERPROPROPERYNAMES; 3.USEOBJECT.Assign () ToupdatemultiplePropertiesREbjects, NotingItmutatestheSheoriginessanEbjectiseStabjectiseStabjectSugoStaSteStrjectiseStabjectiseStabjectiseStabjectiseStern

See all articles