kvadratikus algoritmus

Üdvözlöm, Ön a kvadratikus algoritmus szó jelentését keresi. A DICTIOUS-ban nem csak a kvadratikus algoritmus szó összes szótári jelentését megtalálod, hanem megismerheted az etimológiáját, a jellemzőit és azt is, hogyan kell a kvadratikus algoritmus szót egyes és többes számban mondani. Minden, amit a kvadratikus algoritmus szóról tudni kell, itt található. A kvadratikus algoritmus szó meghatározása segít abban, hogy pontosabban és helyesebben fogalmazz, amikor beszélsz vagy írsz. Akvadratikus algoritmus és más szavak definíciójának ismerete gazdagítja a szókincsedet, és több és jobb nyelvi forráshoz juttat.

Kiejtés

  • IPA:

Főnév

kvadratikus algoritmus

  1. (matematika, algoritmusok)

Kvadratikus algoritmus

A kvadratikus algoritmus olyan algoritmus, amelynek időbonyolultsága ( O(n^2) ), ahol ( n ) a bemenet mérete. Ez azt jelenti, hogy a futási idő arányos a bemenet méretének négyzetével.



Jellemzők

  1. Egyszerűség:

A kvadratikus algoritmusokat általában egyszerű implementálni.

  1. Lassabb nagy méretű adatoknál:

A futási idő gyorsan növekszik a bemenet méretével, így nagy adathalmazoknál nem hatékony.

  1. Általános alkalmazási terület:
    • Kis méretű adatoknál jól használhatók.
    • Problémák, ahol minden elem páronként való összehasonlítására szükség van.



Példák kvadratikus algoritmusokra

  1. Buborékrendezés (Bubble Sort)

Minden elempárt összehasonlít a rendezés érdekében.

  1. Beágyazott ciklusokkal működő algoritmusok

Pl. kettős ciklusban keresünk ismétlődéseket vagy bizonyos tulajdonságokat.

  1. Legnagyobb közös részstring keresése

Két szöveg minden lehetséges párosítását összehasonlítja.



1. Példa: Buborékrendezés

Algoritmus leírása

A buborékrendezés az elemeket páronként összehasonlítja, és a nagyobb elemet hátrébb mozgatja.

Python Implementáció

def bubble_sort(arr):
    """
    Kvadratikus algoritmus: Buborékrendezés
    :param arr: Rendezendő lista
    :return: Rendezett lista
    """
    n = len(arr)
    for i in range(n):
        for j in range(n - i - 1):
            if arr > arr:
                arr, arr = arr, arr
    return arr

# Példa használat
arr = 
print("Eredeti lista:", arr)
sorted_arr = bubble_sort(arr)
print("Rendezett lista:", sorted_arr)

Kimenet:

Eredeti lista: 
Rendezett lista: 

Időbonyolultság: ( O(n^2) )



2. Példa: Legnagyobb közös részstring keresése

Algoritmus leírása

Két szöveg minden lehetséges részstringjét összehasonlítjuk.

Python Implementáció

def longest_common_substring(s1, s2):
    """
    Kvadratikus algoritmus: Legnagyobb közös részstring keresése
    :param s1: Első szöveg
    :param s2: Második szöveg
    :return: Legnagyobb közös részstring
    """
    max_len = 0
    end_pos = 0
    for i in range(len(s1)):
        for j in range(len(s2)):
            l = 0
            while i + l < len(s1) and j + l < len(s2) and s1 == s2:
                l += 1
            if l > max_len:
                max_len = l
                end_pos = i + l
    return s1

# Példa használat
s1 = "abcdfgh"
s2 = "abedfgh"
result = longest_common_substring(s1, s2)
print("Legnagyobb közös részstring:", result)

Kimenet:

Legnagyobb közös részstring: fgh

Időbonyolultság: ( O(n^2) )



3. Példa: Két ismétlődő szám keresése egy listában

Algoritmus leírása

Minden lehetséges párosítást összehasonlítunk, hogy megtaláljuk a duplikált értéket.

Python Implementáció

def find_duplicate(arr):
    """
    Kvadratikus algoritmus: Ismétlődő szám keresése
    :param arr: Lista
    :return: Az első ismétlődő szám
    """
    for i in range(len(arr)):
        for j in range(i + 1, len(arr)):
            if arr == arr:
                return arr
    return None

# Példa használat
arr = 
duplicate = find_duplicate(arr)
print("Ismétlődő szám:", duplicate)

Kimenet:

Ismétlődő szám: 3

Időbonyolultság: ( O(n^2) )



4. Példa: Mátrix szorzása

Algoritmus leírása

Két ( n n )-es mátrix szorzata klasszikusan kvadratikus bonyolultságú.

Python Implementáció

def matrix_multiply(A, B):
    """
    Kvadratikus algoritmus: Mátrix szorzása
    :param A: Első mátrix
    :param B: Második mátrix
    :return: Szorzat mátrix
    """
    n = len(A)
    result =  * n for _ in range(n)]
    for i in range(n):
        for j in range(n):
            for k in range(n):
                result += A * B
    return result

# Példa használat
A = , ]
B = , ]
result = matrix_multiply(A, B)

print("Szorzat mátrix:")
for row in result:
    print(row)

Kimenet:

Szorzat mátrix:

Időbonyolultság: ( O(n^3) ) (kvadratikus, ha ( n )-t rögzítettük egy részdimenzióra)



Összegzés

Gyakori kvadratikus algoritmusok:

  1. Buborékrendezés: ( O(n^2) )
  2. Legnagyobb közös részstring keresése: ( O(n^2) )
  3. Ismétlődések keresése: ( O(n^2) )
  4. Mátrix szorzás klasszikus módon: ( O(n^2 m) )

Használat:

  • Kvadratikus algoritmusokat leginkább kis méretű bemeneteknél érdemes alkalmazni, ahol a futási idő elfogadható.
  • Nagy méretű adatok esetén hatékonyabb algoritmusokat kell keresni (pl. lineáris rendezési algoritmusokat vagy dinamikus programozást).

Fordítások