释义 |
Euclidean AlgorithmAn Algorithm for finding the Greatest Common Divisor of two numbers and , also called Euclid'salgorithm. It is an example of a P-Problem whose time complexity is bounded by a quadratic function of thelength of the input values (Banach and Shallit). Let , then find a number which Dividesboth and (so that and ), then also Divides since
data:image/s3,"s3://crabby-images/e0e4d/e0e4d1585c484398ce7d8b77b1b3b99a16677479" alt="" | (1) |
Similarly, find a number which Divides and (so that and ), then Divides since
data:image/s3,"s3://crabby-images/e13df/e13df8caabcf00955a15e03b547cb1bafcb5b6cf" alt="" | (2) |
Therefore, every common Divisor of and is a common Divisor of and , so the procedure can be iteratedas follows
where is . Lamé showed that the number of steps needed to arrive at the GreatestCommon Divisor for two numbers less than is
data:image/s3,"s3://crabby-images/52598/525982e1b52a5e1708ca05a10974f513b9d63595" alt="" | (8) |
where is the Golden Mean, or times the number of digits in the smaller number. Numerically, Lamé's expression evaluates to
data:image/s3,"s3://crabby-images/89db4/89db419ee203b7799da69e3a32b902f8c195d2f9" alt="" | (9) |
As shown by Lamé's Theorem, the worst case occurs when the Algorithm is applied to twoconsecutive Fibonacci Numbers. Heilbronn showed that the average number of steps is for all pairs with . Kronecker showed that the shortestapplication of the Algorithm uses least absolute remainders. The Quotients obtained aredistributed as shown in the following table (Wagon 1991).Quotient | data:image/s3,"s3://crabby-images/76e3d/76e3d322f8e46649b993f7ac728447c1e6a81abc" alt="" | 1 | 41.5 | 2 | 17.0 | 3 | 9.3 |
For details, see Uspensky and Heaslet (1939) or Knuth (1973). Let be the number of divisions required tocompute using the Euclidean algorithm, and define if . Then
data:image/s3,"s3://crabby-images/b2c01/b2c01b7b074cf860f44f296bc51ffe89e5dd077a" alt="" | (10) |
Define the functions
where is the Totient Function, is the average number of divisions when is fixed and chosen atrandom, is the average number of divisions when is fixed and is a random number coprime to , and is the average number of divisions when and are both chosen at random in . Norton (1990)showed that
data:image/s3,"s3://crabby-images/a76f0/a76f0ae9c6904cd577e0aff47140d8fb8b6b4210" alt="" | (14) |
where is the von Mangoldt Function and is Porter's Constant. Porter (1975) showed that
data:image/s3,"s3://crabby-images/3d10c/3d10ca289c0761aedb86022f3594d21db2d8c583" alt="" | (15) |
and Norton (1990) proved that
data:image/s3,"s3://crabby-images/4e060/4e060d25b4d017fdc7c16f8b15bceebbf535afee" alt="" | (16) |
There exist 22 Quadratic Fields in which there is a Euclidean algorithm (Inkeri 1947). See also Ferguson-Forcade Algorithm References
Bach, E. and Shallit, J. Algorithmic Number Theory, Vol. 1: Efficient Algorithms. Cambridge, MA: MIT Press, 1996.Courant, R. and Robbins, H. ``The Euclidean Algorithm.'' §2.4 in Supplement to Ch. 1 in What is Mathematics?: An Elementary Approach to Ideas and Methods, 2nd ed. Oxford, England: Oxford University Press, pp. 42-51, 1996. Dunham, W. Journey Through Genius: The Great Theorems of Mathematics. New York: Wiley, pp. 69-70, 1990. Finch, S. ``Favorite Mathematical Constants.'' http://www.mathsoft.com/asolve/constant/porter/porter.html Inkeri, K. ``Über den Euklidischen Algorithmus in quadratischen Zahlkörpern.'' Ann. Acad. Sci. Fennicae. Ser. A. I. Math.-Phys. 1947, 1-35, 1947. Knuth, D. E. The Art of Computer Programming, Vol. 1: Fundamental Algorithms, 2nd ed. Reading, MA: Addison-Wesley, 1973. Knuth, D. E. The Art of Computer Programming, Vol. 2: Seminumerical Algorithms, 2nd ed. Reading, MA: Addison-Wesley, 1981. Norton, G. H. ``On the Asymptotic Analysis of the Euclidean Algorithm.'' J. Symb. Comput. 10, 53-58, 1990. Porter, J. W. ``On a Theorem of Heilbronn.'' Mathematika 22, 20-28, 1975. Uspensky, J. V. and Heaslet, M. A. Elementary Number Theory. New York: McGraw-Hill, 1939. Wagon, S. ``The Ancient and Modern Euclidean Algorithm'' and ``The Extended Euclidean Algorithm.'' §8.1 and 8.2 in Mathematica in Action. New York: W. H. Freeman, pp. 247-252 and 252-256, 1991. |