Euklidesen algoritmo

testwikitik
imported>TheklanBot ({{ISBN}} txantiloia sartu, lotura magikoak desagertzen direnean, prest egoteko)(r)en berrikusketa, ordua: 10:20, 16 apirila 2023
(ezb) ←Berrikuspen zaharragoa | Oraingo berrikuspena ikusi (ezb) | Berrikuspen berriagoa→ (ezb)
Nabigaziora joan Bilaketara joan

Euklidesen algoritmoa, matematikan, bi zenbakiren zatitzaile komunetako handiena (zkh) kalkulatzeko erabiltzen den metodo bat da. Euklidesek deskribatu zuen lehenengo aldiz bere Elementuak obran (K.a. 300). Euklidesen algoritmo hedatuarekin, gainera, zatitzaile komunetako handiena emandako bi zenbakien konbinazio lineal moduan adierazteko koefizienteak kalkula daitezke. Algoritmoa hainbat arlotan aplikatzen da; aljebran, zenbaki-teorian eta informatikan, esaterako.

Euklidesen jatorrizko algoritmoa

AB eta CD segmentu neurgarriak

Grekoek matematikari buruz zuten ikuspuntuaren arabera, zenbakiak magnitude geometrikoak dira. Geometria grekoak bi segmenturen neurgarritasuna aztertzen zuen: bi segmentu (zenbaki) AB eta CD neurgarriak dira hirugarren PQ segmentu bat existitzen bada zein aurreko bien barruan egokitzen den n zenbaki osoa adina aldiz, hau da, PQ-k AB eta CD segmentuak neurtzen baditu.

Edozein segmentu bikote ez da neurgarria; pitagorikoek aurkitu zuten moduan, karratuaren diagonala eta aldea ez dira neurgarriak. Bi segmentu neurgarriak direnean, haien arteko neurri komun handiena topatu nahi izaten da.

Euklidesek bere Elementuak lanaren VII liburuko 2. proposizioan bi segmenturen (zenbakiren) neurri komun handiena topatzeko metodo bat deskribatzen du, zenbakiak haien artean lehenak ez diren kasurako.

Txantiloi:Aipu

Metodoa termino geometrikoetan azaldu zen garai hartan. Gaur egungo hizkuntza modernoan algoritmoa horrela deskribatzen da:

Euklidesen jatorrizko algoritmoaren adibidea
  1. Izan bitez AB eta CD bi segmentu, non AB>CD betetzen den. AB-ri CD kentzen diogu behin eta berriz posiblea den bitartean. Amaieran hondarrik geratzen ez bada, orduan CD da neurri komun handiena.
  2. EA hondarra geratzen bada, CD baino txikiagoa izango da eta prozesua errepika daiteke; CD-ri EA kenduko zaio behin eta berriz posiblea den bitartean. Azkenean hondarrik gelditzen ez bada, EA izango da neurri komuna. Bestela, EA baino txikiagoa den FC hondar berria lortuko da.
  3. Prozesua errepikatu behar da hondarrik geratuko ez den arte. Lortutako azken hondarra da neurri komun handiena.

Euklidesen algoritmoa

Zatiketa Euklidearraren definizioaren arabera, bi zenbaki oso a eta b izanik, b>0, beste bi zenbaki oso q eta r existitzen dira eta bakarrak dira non

a=bq+r

betetzen den, 0r<|b| izanik eta b-ren balio absolutua |b| den. Hau da, a zenbaki osoa b zenbaki osoaz zatitzean q zatidura eta r hondarra lortzen dira.

Euklidesen algoritmoa zatiketa euklidearrean oinarritzen da eta bi zenbaki osoren zatitzaile komunetako handiena kalkulatzeko balio du. a eta b bi zenbakiren zatitzaile komunetako handiena adierazteko erabiltzen den notazioa zkh(a,b) da.

Euklidesen algoritmoaren oinarrizko printzipioa zkh(a,b)=zkh(b,r) da. Bertatik ondorioztatzen da zkh(a,0)=a dela. Hortaz, Euklidesen algoritmoa erabiliz a eta b bi zenbakiren zkh(a,b) zatitzaile komunetako handiena horrela kalkulatzen da:

  1. b=0 bada zkh(a,b)=a da.
  2. Bestela, zkh(a,b)=zkh(b,r) da, r izanik a eta b-ren arteko zatiketa euklidearraren hondarra.

Demagun a=r0 eta b=r1 notazioaz adierazten direla. zkh(a,b) kalkulatzeko prozedura orokorra honakoa da:

Urratsa a b Eragiketa q r Esanahia
1 r0 r1 r0 zati r1 q1 r2 zkh(r0,r1)=zkh(r1,r2)
2 r1 r2 r1 zati r2 q2 r3 zkh(r1,r2)=zkh(r2,r3)
3 r2 r3 r2 zati r3 q3 r4 zkh(r2,r3)=zkh(r3,r4)
...
n rn1 rn rn1 zati rn qn rn+1 zkh(rn1,rn)=zkh(rn,rn+1)
n+1 rn rn+1 rn zati rn+1 qn+1 0 zkh(rn,rn+1)=zkh(rn+1,0)

Hondarra txikituz doanez, azkenean 0 hondarra lortuko da eta prozedura amaituko da. a eta b zenbakien zatitzaile komunetako handiena 0 ez den azken hondarra da: rn+1.

zkh(a,b)=rn+1

Adibidea.

a=2366 eta b=273 izanik, zkh(2366,273) horrela kalkulatzen da:

Urratsa a b Eragiketa q r Esanahia
1 2366 273 2366 zati 273 8 182 zkh(2366,273)=zkh(273,182)
2 273 182 273 zati 182 1 91 zkh(273,182)=zkh(182,91)
3 182 91 182 zati 91 2 0 zkh(182,91)=zkh(91,0)

zkh(2366,273)=zkh(273,182)=zkh(182,91)=zkh(91,0) sekuentziaren bidez, honakoa ondorioztatzen da: zkh(2366,273)=zkh(91,0) eta zkh(91,0)=91 denez, zkh(2366,273)=91 da.

Orokortasuna

Euklidesen algoritmoak ez du zenbaki arruntetarako soilik balio; hondarra uzten duen zatiketa bat dagoen beste kasuetara ere orokor daiteke. Koefiziente arrazionalak dituzten polinomioen arteko zatiketa euklidearra ere definitu daitekeenez, haien arteko zatitzaile komunetako handiena kalkula daiteke.

Adibidea.

Euklidesen algoritmoaren bidez P(x)=x5+2x3+x eta Q(x)=x41 polinomioen arteko zatitzaile komunetako handiena horrela kalkulatzen da:

Urratsa Eragiketa Esanahia
1 x5+2x3+x zati x41; hondarra: 2x3+2x zkh(x5+2x3+x,x41)=zkh(x41,2x3+2x)
2 x41 zati 2x3+2x; hondarra: x21 zkh(x41,2x3+2x)=zkh(2x3+2x,x21)
3 2x3+2x zati x21; hondarra: 0 zkh(2x3+2x,x21)=zkh(x21,0)

Hortaz, P(x) eta Q(x) polinomioen zatitzaile komunetako handiena x21 dela ondorioztatzen da.

Deskribapen formala

Algoritmoa modu formalagoan adierazteko sasikodea erabil daiteke. Kasu honetan, "xmody" adierazpenaren esanahia "x zati y eragiketarekin lortutako hondarra" da (ikus Aritmetika modular).

Euklides algoritmoa


Algoritmo hau ez da eraginkorra konputagailuan inplementatua izateko, ri balio guztiak gordetzea eskatzen duelako.

Euklidesen algoritmo hedatua

Bi zenbaki osoren zatitzaile komunetako handiena haien konbinazio lineal moduan idatz daiteke. Formalki, a eta b bi zenbaki oso izanik, zkh(a,b)=as+bt betetzen duten s eta t koefiziente osoak existitzen dira, a0 edo b0 izanik. Gainera, zkh(a,b) da a eta b zenbakien konbinazio lineal moduan idatz daitekeen zenbaki oso positiborik txikiena. s eta t koefizienteak ez dira bakarrak.

Euklidesen algoritmo hedatuari esker, zkh(a,b) kalkulatzeaz gain s eta t koefiziente osoak kalkula daitezke.

Oinarrizko printzipioak

Euklidesen algoritmo hedatua azaltzeko, hainbat modu daude. Erabilienetako bat honako hau da:

  1. Euklidesen algoritmoa erabiltzea. Urrats bakoitzean, a zenbakia b zenbakiaz zatitzean, q zatidura eta r hondarra lortzen dira. a=bq+r ekuazioaren bidez adierazten da.
  2. Ekuazio bakoitzean r hondarra askatzen da (r=abq).
  3. Azken ekuazioaren hondarra azken-aurrekoan ordezkatzen da, eta azken-aurrekoa azken-aurrekoaren aurrekoan eta horrela lehenengo ekuaziora iritsi arte. Urrats bakoitzean r hondarra zenbakien konbinazional lineal moduan adierazita agertuko da.

Aplikazioak

Zatikien sinplikazioa

Zatikiekin eragitean, sinplifikazioak egitea oso garrantzitsua gertatzen da. Esaterako, 6591 eta 57 zatikiak baliokideak dira (ikus Zenbaki arrazional). Izan ere, c0 bada, ab=cacb zatikiak baliokideak dira. Oro har, ab zatikia sinplifikatzeko, a eta b zenbakiak haien zatitzaile komunetako handienaz zatitu behar dira.

Adibidea.

166249 zatikia sinplifikatzeko, zkh(166,249)=83 denez, 166÷83=2 eta 249÷83=3 zatiketak egiten dira, eta 166249=23 baliokideak direla ondorioztatzen da.

Zatiki jarraituak

Euklidesen algoritmoa aplikatzean egiten den zatiketa euklidear sorta ab zatikia zatiki jarraitu moduan adierazteko erabil daiteke. Izan ere, a=bq+r eta r0 badira, zera betetzen da:

ab=q+1br

Adibidea.

ab=931645826 zatikia izanik, zkh(93164,5826) Euklidesen algoritmoa erabiliz kalkulatzean, honako zatiketa euklidear sorta egiten da:

Urratsa Eragiketa q r Esanahia
1 93164 zati 5826 15 5774 93164=5826×15+5774
2 5826 zati 5774 1 52 5826=5774×1+52
3 5774 zati 52 111 2 5774=52×111+2
4 52 zati 2 26 0 52=2×26+0

Ekuazio horiek guztiak era honetan ere idatz daitezke:

  1. 931645826=15+158265774
  2. 58265774=1+1577452
  3. 577452=111+1522
  4. 522=26

Bigarren ekuazioa lehenengoan ordezkatuz gero, honakoa lortzen da:

931645826=15+11+1577452

Gainerakoak ere ordenatuz, honako adierazpena lortzen da:

931645826=15+11+1111+126

Oro har, zera baiezta daiteke:

ab=q1+1q2+1q3+1...qn1+1qn

Biderketarekiko alderantzizko modular

Artikulu nagusia: Biderketarekiko alderantzizko modular.

Bi zenbaki oso a eta b kongruenteak dira modulu m , m balioaz zatitzean hondar bera lortzen bada. Adibidez, 7 eta 12 kongruenteak dira modulu 5, 7 zenbakia eta 12 zenbakia 5ez zatitzean 2 hondarra lortzen delako. a eta b zenbakiak kongruenteak direla modulu m adierazteko

ab(modm)

notazioa erabiltzen da. Aurreko adibideko kongruentzia, beraz, horrela adierazten da:

712(mod5).

Demagun a,b eta m balioak ezagunak direla, baina honako kongruentzia betetzen duen x ezezaguna dela:

axb(modm)

a1a1(modm) betetzen duen a1 balioa aurkitu behar da. Horrela, aurreko ekuazioa a1-ekin biderkatuz, nahi den soluzioa lortuko da:

xa1(modm)

a1 balioa aren alderantzizkoa modulu m dela esaten da.

Balio hori ez da beti existitzen. Esaterako, a=4 eta m=6 balioetarako ez da existitzen a1 zenbaki osorik non a141(mod6) betetzen den. Izan ere, a1 balioa existitzeko zkh(a,m)=1 bete behar da, hau da, zenbakiak elkarrekiko lehenak izan behar dute. Euklidesen algoritmo hedatua erabiltzean (b=m) , 1=as+mt lortzen bada, orduan s balioa aren alderantzizkoa da, modulu m. Adibidez, honako ekuazio hau ebatzi nahi bada:

5x2(mod9)

Orduan, Euklidesen algoritmo hedatuarekin zkh(5,9)=1=5(2)+9(1) lortzen da. zkh(5,9)=1 denez, 5-ak badu alderantzizkoa modulu 9. Gainera, 1=5(2)+9(1) denez, alderantzizko hori 2 da. Hortaz,

x2(2)(mod9),

hau da, x=4 da.

Bézouten Identitatea

Artikulu nagusia: Bézouten identitate.

Bézouten identitateak zera dio: zeroren ezberdinak diren a eta b bi zenbaki oso eta d haien zatitzaile komun handiena izanik, honakoa betetzen duten x eta y bi zenbaki oso existitzen direla:

ax+by=d

x eta y koefizienteak eta d=zkh(a,b) haien zatitzaile komun handiena Euklidesen algoritmo hedatuaren bidez kalkula daitezke.

Algoritmoaren konplexutasuna

Lamé-ren teoremak baieztatzen du Euklidesen algoritmoa aplikatzean kasurik okerrena Fibonacci-ren segidako ondoz ondoko bi zenbakiren zatitzaile komunetako handiena kalkulatzean ematen dela.

Adibidea.

f10=55 eta f11=89 zenbakien zatitzaile komunetako handiena kalkulatzeko honako eragiketak egin behar dira:

Euklidesen algoritmoa aplikatzean egiten den zatiketa kopuruaren grafikoa. Gorriak eragiketa gutxi adierazten du; kolore urdinagoek, aldiz, eragiketa kopuru handiagoa adierazten dute.
Urratsa Eragiketa q r Esanahia
1 89 zati 55 1 34 zkh(89,55)=zkh(55,34)
2 55 zati 34 1 21 zkh(55,34)=zkh(34,21)
3 34 zati 21 1 13 zkh(34,21)=zkh(21,13)
4 21 zati 13 1 8 zkh(21,13)=zkh(13,8)
5 13 zati 8 1 5 zkh(13,8)=zkh(8,5)
6 8 zati 5 1 3 zkh(8,5)=zkh(5,3)
7 5 zati 3 1 2 zkh(5,3)=zkh(3,2)
8 3 zati 2 1 1 zkh(3,2)=zkh(2,1)
9 2 zati 1 2 0 zkh(2,1)=zkh(1,0)

Ikusten denez, bi digituko bi zenbaki horietarako 9 zatiketa egin behar izan dira. Oro har, egindako zatiketa kopurua zenbakiek duten digito kopurua bider 5 baino altuagoa ez da inoiz izango.

Konplexutasun konputazionalari dagokionez, n eta m-ren zkh(n,m) kalkulatzeko O(logn) zatiketa egin beharko dira, n>m izanik.

Brigitte Valleek frogatu zuen bi zenbakiak n bitetan adieraz badaitezke, orduan bataz bestean egin beharreko zatiketa kopurua π26n dela.

Hala ere, ez da nahikoa zatiketa kopurua ezagutzea. Aurretik aipatu den moduan, Euklidesen algoritmoak polinomioetan eta zenbaki osoetan funtzionatzen du eta, oro har, edozein eremu euklidearretan. Kasu bakoitzean, algoritmoaren konplexutasuna egin behar den zatiketa kopuruaren eta zatiketa bakoitza egitearen kostuaren mende dago. Polinomioen kasuan, egin beharreko zatiketa kopurua O(logn) da, n polinomioen gradua izanik.

Bibliografia

  • von zur Gathen, Joachim; Gerhard, Jürgen (2003). «The Euclidean Algorithm». Modern Computer Algebra
  • Cambridge University Press. Txantiloi:ISBN.
  • Shoup, Victor (2008). «Euclid’s algorithm». A Computational Introduction to Number Theory and Algebra
  • Cambridge University Press. Txantiloi:ISBN.
  • Johnsonbaugh, Richard (2005). «Introducción a la teoría de números». Matemáticas Discretas. México: PEARSON EDUCACIÓN. Txantiloi:ISBN.
  • Ralph P. Grimaldi (1998). «Propiedades de los números enteros: Inducción matemática». Matemáticas Discreta y Combinatoria. México: Addison Wesley Longman de México. Txantiloi:ISBN.
  • Lipschutz, Seymour; Lipson, Marc (2009). «Propiedades de los enteros». Matemáticas Discretas. McGraw-Hill. Txantiloi:ISBN.
  • Brassard, Gilles; Bratley, Paul (1997). «Análisis de algoritmos». Fundamentos de Algoritmia. Madrid: PRENTICE HALL. Txantiloi:ISBN.
  • Vallée, Brigitte (2002). «Dynamical Analysis of α-Euclidean Algorithms»
  • Journal of Algorithms 44 (1). ISSN 0196-6774 , pp. 246-285.
  • Cormen, Thomas; Leiserson, Charles; Rivest, Ronald; Stein, Clifford (2009). «Number-Theoretic Algorithms». Introduction to Algorithms. The MIT Press. Txantiloi:ISBN.
  • Barrera Mora, Fernando (2005). «Definiciones y resultados generales». Introducción a la Teoría de Grupos
  • Publicaciones Electrónicas de la Sociedad Matemática Mexicana. Txantiloi:ISBN.
  • Cárdenas, Humberto; Lluis, Emilio; Raggi, Francisco; Tomás, Francisco (2004). «Divisibilidad». Álgebra Superior. México: Trillas. Txantiloi:ISBN.
  • Pérez Seguí, María Luisa (2006). «Divisibilidad». Teoría de Números. Instituto de Matemáticas, UNAM. Txantiloi:ISBN.
  • Sánchez Velázquez, Jesús (1998). «Algoritmos para números grandes». Introducción al análisis de algoritmos. México: Trillas. Txantiloi:ISBN.
  • Baldor, Aurelio (2008). «Máximo común divisor». Álgebra. México: Grupo Editorial Patria. Txantiloi:ISBN.

Euklidesen algoritmoa polinomioekin

Izan bitez f, g ∈ K[x] eta deg f ≥ deg g. Zatiketaren algoritmoa erabiliz, f = gh + r non r = 0 edo deg r < deg g den. Orduan,

Bigarren kasuan, zatiketaren algoritmoa erabil dezakegu g eta r-rako eta lortzen dugun hondar berria 0 ez bada, r-ren maila baino txikiagoa izango du. Behin eta berriro erabiliko dugu algoritmoa hondarra 0 izan arte. Hori noizbait gertatuko da eta orduantxe erabili dugun zatitzailea moniko eginez, lortu dugu zatitzaile komun handienaren definizioa betetzen duen polinomioa. Hala dela ikusteko, polinomio horrek Bézouten identitatea betetzen dela ondorioztatzen da lehenengo. Hori Euklidesen algoritmoak ematen du, zenbakien kasuan ikusi dugun moduan. Behin identitate hori eskutan, argi dago f eta g-ren edozein zatitzailek lortu dugun polinomioa zatituko duela.

Kanpo estekak

Txantiloi:Autoritate kontrola