Fronta je jedním ze základních datových typů a slouží k ukládání a výběru dat takovým způsobem, aby prvek, který byl uložen jako první, byl také jako první vybrán. Tomuto principu se říká FIFO - first in, fist out. Opačný přístup - LIFO - last in, first out - používá datový typ zásobník.
Speciálním případem fronty je tzv. prioritní fronta, ve které mohou prvky s vyšší prioritou předbíhat na výstupu ty s nižší prioritou.
Typické operace
- addLast (enqueue) – Vloží prvek do fronty.
- deleteFirst (poll, dequeue) – Získá a odstraní první prvek (hlavu) fronty.
- getFirst (peek) – Získá první prvek fronty.
- isEmpty – Dotaz na prázdnost fronty.
- size – Vrátí počet obsažených prvků.
Využití
Fronta má v informatice široké využití, toto jsou některé příklady:
- Synchronizační primitivum
- Operátor roura (pipe) - komunikace mezi procesy v operačních systémech
- Kruhový buffer - vyrovnávací paměť pro datové toky
Kód
/**
* Fronta - implementovana jako spojovy seznam
*/
public class Queue {
private Node first;
private Node last;
private int size;
public Queue() {
this.size = 0;
}
/**
* Prida na konec fronty prvek - asymptoticka sloztitost O(1)
* @param i prvek k vlozeni
*/
public void addLast(int i) {
Node n = new Node(i);
if(getSize() == 0) {
this.first = n;
this.last = n;
} else {
this.last.next = n;
this.last = n;
}
size++;
}
/**
* Odebere z fronty prvni prvek - asymptoticka sloztitost O(1)
* @return prvni prvek
*/
public int deteteFirst() {
if(getSize() == 0) throw new IllegalStateException("Fronta je prazdna");
int value = first.value;
first = first.next;
size--;
return value;
}
/**
* Vrati prvni prvek fronty
* @return prvni prvek
*/
public int getFirst() {
if(getSize() == 0) throw new IllegalStateException("Fronta je prazdna");
return first.value;
}
/**
* Getter na delku
* @return delka fronty
*/
public int getSize() {
return size;
}
/**
* Dotaz pra prazdnost
* @return true, pokud je fronta prazdna
*/
public boolean isEmpty() {
return this.size == 0;
}
/**
* Klasicka toString metoda, vraci textovou reprezentaci objektu
* @return textova reprezentace objektu
*/
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
Node curr = first;
for(int i = 0; i < this.size; i++) {
builder.append(curr.value).append(" ");
curr = curr.next;
}
return builder.toString();
}
/**
* Vnitrni reprezentace prvku
*/
private class Node {
private int value;
private Node next;
private Node(int value) {
this.value = value;
}
}
}
SEO od společnosti Digital Pylon
Online casino s algoritmem
České casino online online slot-vegas.cz
Hrajte nejlepší hry jako je GoodGame Empire.
Zajímavé články: Jak najít práci snů? Zvolte kariéru v IT!, Češi mají rádi hrací automaty online, Jak funguje algoritmické obchodování Casino, Online výuka Algoritmus a online marketing mají svá pravidla, Automaty, Matematický vliv, Ratings, Jak fungují algoritmy hazardních her online: více znalostí, více peněz, SYPWAI - nástroj pro vědecký vývoj, Vynikají na globálním trhu: Nejlepší vývojáři softwaru pro online výherní automaty, Jak si vybrat nejlepší české online casino, Proč byste měli hrát online casino VPN revoluce, Kde najdeme algoritmy v každodenním životě?, Čeká vás pracovní pohovor mimo město? Podívejte se, jak dokonale zvládnout včasný příchod, 5 úžasných technologií ze světa hazardních her, Mirror and access to Mostbet, Svou kancelář můžete mít stále po ruce, Jaké výhody má digitalizovaná firma oproti off-line konkurenci?, Jaký systém vybrat pro snadné řízení výroby?, Nahradí umělá inteligence ajťáky?, Důvody, proč používat SnapTik ke stahování videí TikTok, Dokonalý den na pláži: Co si vzít s sebou, aby byl výlet zábavný a bezpečný?, Jak přežít dlouhý let?, Go pay GoodGame Empire, Blockchain, Rozhovor, Umělá inteligence, Ochranná známka pre softvér: Prečo ju registrovať?, Role kryptografických algoritmů v zabezpečení online kasin, Jaké jsou náklady na nákup 3D tiskárny?, Jak algoritmy vylepšují online zážitky v roce 2025, Epilace laserem a péče o pokožku před a po ní, Byty k pronájmu Sokolov - výhody a rizika pronájmu bytu bez realitky, Filmy a seriály plné hádanek: kryptografie jako hlavní téma Kdy obnovit data z disku běžně dostupným softwarem a kdy už se obrátit na profesionály?>