最大公约数的三种算法复杂度分析时间计算

合集下载

求最大公约数的两种算法

求最大公约数的两种算法

求最大公约数的两种算法最大公约数(GCD)是指能够同时整除两个或多个整数的最大正整数。

在数学和计算机科学中,求最大公约数是一个常见的问题,并有多种算法可以解决。

以下是两种常见的求最大公约数的算法:1.暴力法:暴力法,也称为穷举法或试除法,是最简单直观的求最大公约数的方法。

该方法使用一个循环来遍历从2到较小的那个数之间所有的可能公约数,然后找到最大的。

算法步骤:-输入两个整数a和b,其中a>=b。

-从2开始,从小到大的顺序依次遍历所有的整数,直到找到最大的公约数。

-对于每一个遍历到的整数i,判断它是否同时整除a和b,如果是则更新最大公约数。

-返回最大公约数。

该算法的时间复杂度取决于较小整数b的大小,即O(b)。

然而,该算法对于较大的整数效率比较低,而且无法处理负整数。

2.辗转相除法(欧几里得算法):辗转相除法是一种通过反复用较小数除较大数,然后用余数去除旧的较小数,直到余数为0的方式来求解最大公约数的算法。

该算法基于下面的原理:两个整数a和b的最大公约数等于b和a mod b的最大公约数。

算法步骤:-输入两个整数a和b,其中a>=b。

- 计算a mod b,使用较小数b去除较大数a,将余数保存下来。

-如果余数为0,则b即为最大公约数。

-如果余数不为0,则将b赋值给a,将余数赋值给b,回到第二步继续计算。

-返回b作为最大公约数。

辗转相除法的时间复杂度较低,约为O(log b)。

它比暴力法更加高效且适用于处理较大整数。

此外,该算法也能正确处理负整数。

这两种算法是求最大公约数最常用的方法,它们在数学和计算机科学的许多领域都有广泛的应用。

可以根据具体情况选择合适的算法来求解最大公约数。

matlab最大公约数 三种算法

matlab最大公约数 三种算法

算法设计与分析11信本余启盛 118632011004一、上机目的及内容1.上机内容求两个自然数m和n的最大公约数。

2.上机目的(1)复习数据结构课程的相关知识,实现课程间的平滑过渡;(2)掌握并应用算法的数学分析和后验分析方法;(3)理解这样一个观点:不同的算法能够解决相同的问题,这些算法的解题思路不同,复杂程度不同,解题效率也不同。

二、实验原理及基本技术路线图(1)至少设计出三个版本的求最大公约数算法;(2)对所设计的算法采用大O符号进行时间复杂性分析;(3)上机实现算法,并用计数法和计时法分别测算算法的运行时间;(4)通过分析对比,得出自己的结论。

三、所用仪器、材料(设备名称、型号、规格等或使用软件)1台PC及VISUAL C++6.0软件matlab .2008四、实验方法、步骤(或:程序代码或操作过程)实验采用三种方法求最大公约数1、连续整数检测法。

2、欧几里得算法3、蛮力法(短除法)根据实现提示写代码并分析代码的时间复杂度:算法一:连续整数检测法。

CommFactor1输入:两个自然数m和n输出:m和n的最大公约数1.判断m和n哪个数小,t=min(m,n)2.如果m%t==0&&n%t==0 ,结束2.1 如果t不是m和n的公因子,则t=t-1;3. 输出t ;根据代码考虑最坏情况他们的最大公约数是1,循环做了t-1次,最好情况是只做了1次,可以得出O(n)=n/2;算法二:欧几里德算法CommFactor2输入:两个自然数m和n输出:m和n的最大公约数1. r = m % n;2. 循环直到r 等于02.1 m = n;2.2 n = r;2.3 r = m % n;3. 输出n ;根据代码辗转相除得到欧几里得的: O(n)= log n算法三:蛮力法(短除法)CommFactor3输入:两个自然数m和n输出:m和n的最大公约数1.factor=1;2.循环变量i从2-min(m,n),执行下述操作:2.1 如果i是m和n的公因子,则执行下述操作:2.1.1 factor=factor*i;2.1.2 m = m / i; n = n / i;2.2 如果i不是m和n的公因子,则i=i+1;3. 输出factor;根据代码考虑最坏情况他们的最大公约数,循环做了i-1次;最好情况是只做了1次,可以得出: O(n)=n/2;MATLAB程序代码:main.mx=fix(rand(1,1000)*1000);y=fix(rand(1,1000)*1000);for i=1:1000A(i)=CommFactor2(x(i),y(i));endx=x';y=y';算法一:function r=CommFactor1(m,n)tic;if m>n)t=n;else t=m;while(t)if(m%t==0&&n%t==0)break;else t=t-1;endendr=ttoc;算法二:function r=CommFactor2(m,n)tic;r=mod(m,n);while r~=0m=n;n=r;r=mod(m,n);endr=n;toc;算法三:function factor=CommFactor3(m,n)tic;factor=1;themax=max(m,n);for i=2:1:themaxwhile (mod(m,i)==0)&&(mod(n,i)==0) factor=factor*i;m=m/i;n=n/i;endendtoc;三种算法时间复杂度比较:(c++语言)#include"iostream.h"#include"stdio.h"#include"stdlib.h"#include"time.h"#define N 100int w,w2,w3;//用于计数int f1(int m,int n){int t;if(m>n)t=n;else t=m;while(t){if(m%t==0&&n%t==0)break;else t=t-1;w++;}return t;}int f2(int m,int n){int r;r=m%n;w2=1;while(r!=0){m=n;n=r;r=m%n;w2++;}return n;}int f3(int m,int n){int i, factor = 1;for (i = 2; i <= m && i <= n; i++){while (m % i == 0 && n % i == 0) //此处不能用if语句{factor = factor * i;m = m / i; n = n / i;w3++;}}return factor;}int main(void){int m,n;printf(" 请输入m,n :\n");scanf("%d%d",&m,&n);int k;k=f1(m,n);printf(" 方法一最大公约数为:%d\n",k);k=f2(m,n);printf(" 方法二最大公约数为:%d\n",k);k=f3(m,n);printf(" 方法三最大公约数为:%d\n",k);printf("\n--------------------\n");printf("\n计数器显示结果:\n\n\n");printf("方法一:%d \n",w2);printf("方法二:%d \n",w);printf("方法三:%d \n",w3);printf("\n--------------------\n");float a,i;clock_t start,finish;double usetime;i=0;start= clock();while (i<1000000){f1(m,n);i++;}finish=clock();usetime= finish-start;printf(" 方法一用时%.f*10^(-6) 豪秒\n", usetime);i=0;start= clock();while (i<1000000){f2(m,n);i++;}finish=clock();usetime= finish-start;printf(" 方法二用时%.f*10^(-6) 豪秒\n", usetime);i=0;start= clock();while (i<1000000){f3(m,n);i++;}finish=clock();usetime= finish-start;printf(" 方法三用时%.f*10^(-6) 豪秒\n", usetime); }结果:(示例)。

c语言求两个数最大公约数,穷举法的时间复杂度

c语言求两个数最大公约数,穷举法的时间复杂度

c语言求两个数最大公约数,穷举法的时间复杂度C语言求两个数最大公约数,穷举法的时间复杂度在计算机科学领域中,我们经常需要解决各种数学问题,例如求两个数的最大公约数。

而在C语言中,我们可以使用穷举法(也称为暴力法)来求解最大公约数。

在本篇文章中,我们将深入探讨C语言中求两个数最大公约数的问题,并分析穷举法的时间复杂度。

1. 最大公约数的概念最大公约数指的是两个或多个整数共有约数中最大的一个。

在数学上,常用的求最大公约数的方法有辗转相除法、更相减损术和质因数分解法等。

而在计算机科学中,我们可以使用穷举法来求解最大公约数。

下面,我们将以C语言为例,介绍如何使用穷举法来求解两个数的最大公约数。

2. C语言求最大公约数在C语言中,我们可以使用穷举法来求解两个数的最大公约数。

穷举法的基本思路是从较小的数开始,逐渐减小,直到找到两个数的一个公约数为止。

以下是一个简单的C语言程序示例:```c#include <stdio.h>int gcd(int a, int b) {int min = a < b ? a : b;int max = a > b ? a : b;int result = 0;for (int i = 1; i <= min; i++) {if (min % i == 0 && max % i == 0) {result = i;}}return result;}int main() {int a, b;printf("请输入两个整数:");scanf("%d %d", &a, &b);printf("它们的最大公约数是:%d\n", gcd(a, b)); return 0;}```3. 穷举法的时间复杂度穷举法的时间复杂度可以通过一个简单的分析得出。

在上面的C语言程序中,我们使用了一个for循环来进行穷举。

最大公约数的方法及其原理

最大公约数的方法及其原理

最大公约数的方法及其原理
求最大公约数的方法有多种,下面介绍其中两种常用的方法及其原理:
1. 辗转相除法(又称欧几里德算法):假设两个数为a和b,其中a>b。

通过a除以b得到余数r,再用b除以r得到余数
r1,依此类推直到余数为0为止。

此时,b即为最大公约数。

原理:根据辗转相除法,假设a=b*q+r,其中q为商,r为余数(0<=r<b)。

如果c同时是a和b的公约数,那么c也是a 和r的公约数,反之亦然。

因此,可以通过连续除法的过程,不断更新a和b的值,最终得到最大公约数。

2. 更相减损术:假设两个数为a和b,其中a>b。

通过用a-b 得到差c,然后用c和较小的数b进行同样的操作,直到a、b 相等,此时a(或b)即为最大公约数。

原理:更相减损术的思路是将较大数减去较小数,得到一个新的差值。

如果c同时是a和b的公约数,那么c也是b和差值c的公约数,反之亦然。

通过连续的减法操作,最终得到最大公约数。

这两种方法都是经典的求最大公约数的算法,但是辗转相除法相较于更相减损术的效率更高,因此在实际应用中更常使用辗转相除法计算最大公约数。

最大公约数的三种算法复杂度分析时间计算

最大公约数的三种算法复杂度分析时间计算

,昆明理工大学信息工程与自动化学院学生实验报告( 2011 —2012 学年第 1 学期)课程名称:算法设计与分析开课实验室:信自楼机房444 2011 年10月 12日!一、上机目的及内容1.上机内容求两个自然数m和n的最大公约数。

2.上机目的(1)复习数据结构课程的相关知识,实现课程间的平滑过渡;(2)掌握并应用算法的数学分析和后验分析方法;(3)理解这样一个观点:不同的算法能够解决相同的问题,这些算法的解题思路不同,复杂程度不同,解题效率也不同。

?二、实验原理及基本技术路线图(方框原理图或程序流程图)(1)至少设计出三个版本的求最大公约数算法;(2)对所设计的算法采用大O符号进行时间复杂性分析;(3)上机实现算法,并用计数法和计时法分别测算算法的运行时间;(4)通过分析对比,得出自己的结论。

三、所用仪器、材料(设备名称、型号、规格等或使用软件)&1台PC及VISUAL C++软件四、实验方法、步骤(或:程序代码或操作过程)实验采用三种方法求最大公约数1、连续整数检测法。

2、欧几里得算法@3、分解质因数算法根据实现提示写代码并分析代码的时间复杂度:方法一:int f1(int m,int n){int t;if(m>n)t=n;else t=m;-while(t){if(m%t==0&&n%t==0)break;else t=t-1;}return t;}根据代码考虑最坏情况他们的最大公约数是1,循环做了t-1次,最好情况是只做了1次,可以得出O(n)=n/2;!方法二:int f2(int m,int n){int r;r=m%n;while(r!=0){m=n;n=r;—r=m%n;}return n;}根据代码辗转相除得到欧几里得的O(n)= log n方法三:int f3(int m,int n):{int i=2,j=0,h=0;int a[N],b[N],c[N];while(i<n){if(n%i==0){j++;。

最大公约数的计算方法

最大公约数的计算方法

最大公约数的计算方法最大公约数是数学中的基本概念之一,是指两个或多个数中最大的公约数。

在数学运算中,求解最大公约数是非常重要的,因此有多种计算方法,下面为大家介绍一些简便易行的方法。

一、辗转相除法辗转相除法,也称为欧几里得算法,是求两个数的最大公约数的常用方法之一。

该方法通过逐步取余,不断缩小问题规模,最终得出结果。

具体步骤如下:1. 将两个数中较大的数除以较小的数,得到余数。

2. 将较小的数和余数作为新的两个数,再次执行第一步操作。

3. 重复以上步骤,直到余数为0为止,此时的除数即为最大公约数。

下面以70和45为例,进行演示:1. 70 ÷ 45 = 1 余 252. 45 ÷ 25 = 1 余 203. 25 ÷ 20 = 1 余 54. 20 ÷ 5 = 4 余 0因此,70和45的最大公约数为5。

二、更相减损术更相减损术是中国古代传统的算术方法之一,也适用于求两个整数的最大公约数。

该方法通过不断相减,使得两个数的差趋近于最大公约数。

具体步骤如下:1. 将两个数中较大的数减去较小的数,得到差值。

2. 将较小的数和差值作为新的两个数,再次执行第一步操作。

3. 重复以上步骤,直到两个数相等或其中一个数为0,则最后的数即为最大公约数。

下面以80和56为例,进行演示:1. 80 - 56 = 242. 56 - 24 = 323. 32 - 24 = 84. 24 - 8 = 165. 16 - 8 = 8因此,80和56的最大公约数为8。

三、质因数分解法质因数分解法是将数分解为质因数的乘积,然后根据质因数的公共部分求出最大公约数的方法。

该方法适用于小数的求解。

具体步骤如下:1. 将两个数分别分解为质因数的乘积。

2. 将相同的质因数乘起来,得到公共部分。

3. 公共部分中的质因数乘积即为最大公约数。

下面以28和70为例,进行演示:1. 28 = 2 × 2 × 7,70 = 2 × 5 × 72. 相同的质因数有2和7,2 × 7 = 14因此,28和70的最大公约数为14。

C++丨常见的四种求最大公约数方法!赶紧收藏!

C++丨常见的四种求最大公约数方法!赶紧收藏!

C++⼁常见的四种求最⼤公约数⽅法!赶紧收藏!为了更好的了解算法的概念,今天会分享⼀些C++求最⼤公约数⼏种常见的算法。

第⼀种:穷举法之⼀穷举法,也叫枚举法,求最⼤公约数时从两者中较⼩的数开始,由⼤到⼩列举,直到找到第⼀个公约数为⽌。

解释:拿其中⼀个数出来,⽤⼀个临时变量(tem)保存,每次都把那两个数除以这个临时变量。

如果能除断,直接返回tem;如果不能除断,tem- -,直到都能除断,再返回tem。

tem就是它们的最⼤公约数。

#include <iostream>using namespace std;int CommFactor1(int m, int n); //函数的声明int main(){int a, b;cin >> a >> b;cout << "这两个数的最⼤公约数为:" << CommFactor1(a,b)<< endl;return 0;}int CommFactor1(int m,int n){int tem;for (tem = m;; tem--){if (m % tem == 0 && n % tem == 0){break;}}return tem;}第⼆种:穷举法之⼆解释:求出两数的所有公因⼦,再把公因⼦累乘得到最⼤公约数。

#include <iostream>using namespace std;int CommFactor2(int m, int n); //函数的声明int main(){int a, b;cin >> a >> b;cout << "这两个数的最⼤公约数为:" << CommFactor2(a,b)<< endl;return 0;}int CommFactor2(int m,int n){int i;int factor = 1;for (i=2;i<=m&&i<<n;i++){while(m % i == 0 && n % i == 0) //这⾥不能⽤if语句,因为可能会有重复的公因⼦{factor = factor * i;m = m / i;n = n / i;}}return factor;}第三种:辗转相除法辗转相除法,⼜称欧⼏⾥得算法。

最大公约数的三种算法复杂度分析时间计算

最大公约数的三种算法复杂度分析时间计算

最大公约数的三种算法复杂度分析时间计算1.辗转相除法(欧几里得算法)辗转相除法是一种基于递归的算法,它通过不断地用两个数中较大的数除以较小的数,直到两个数相等为止。

这时,较小的数就是最大公约数。

例如,求解49和28的最大公约数:-49÷28=1 (21)-28÷21=1 (7)-21÷7=3 0所以最大公约数为7辗转相除法的时间复杂度分析如下:设两个数中较大的数为a,较小的数为b,a mod b 的结果为r。

- 最好情况:当b能够整除a时,时间复杂度为O(loga),因为每次递归时a和b的值都会减少至原来的一半。

-最坏情况:当a和b互质时,时间复杂度为O(a/b)。

例如,当a=2n 时,每次递归的b的值都会减少至1- 平均情况:时间复杂度是O(logab)的。

2.更相减损术更相减损术是一种基于减法的算法,它通过不断地用两个数中较大的数减去较小的数,直到两个数相等为止。

这时,较小的数就是最大公约数。

例如,求解49和28的最大公约数:-28-21=7-21-7=14-14-7=7所以最大公约数为7更相减损术的时间复杂度分析如下:设两个数中较大的数为a,较小的数为b。

- 最好情况:当a和b的差值为1时,时间复杂度为O(logb),因为每次减法操作后的差值都会减少一半。

-最坏情况:当a和b互质时,时间复杂度为O(a-b)。

例如,当a=2n 时,每次减法操作的差值都会减少至1-平均情况:时间复杂度为O(a-b)的。

3. Stein算法(二进制法)Stein算法是一种基于位运算的算法,它通过在两个数中同时除去2的因子,直到两个数都变为奇数。

然后,继续用较小的数减去较大的数,直到两个数相等为止。

这时,较小的数就是最大公约数的2的因子。

例如,求解49和28的最大公约数:-49÷2=24-28÷2=14-24÷2=12现在两个数都是奇数,继续减法操作:-7-12=-5-12-7=5所以最大公约数为5Stein算法的时间复杂度分析如下:设两个数中较大的数为a,较小的数为b。

最大公约数计算方法

最大公约数计算方法

最大公约数计算方法最大公约数(Greatest Common Divisor,简称GCD)是数学中的一个重要概念,指两个或多个整数共有约数中最大的一个。

在日常生活和编程中,我们经常需要计算两个数的最大公约数。

本文将详细介绍最大公约数的计算方法。

一、列举法列举法是最直观的计算最大公约数的方法。

首先,分别列出两个数的所有约数,然后找出最大的共同约数。

例如,计算48和18的最大公约数:48的约数有:1,2,3,4,6,8,12,16,24,4818的约数有:1,2,3,6,9,18最大公约数为6。

二、辗转相除法(也称欧几里得算法)辗转相除法是一种更高效的计算最大公约数的方法。

具体步骤如下:1.将两个数a和b进行比较,使a≥b。

2.用a除以b,得到余数r(0≤r<b)。

3.若r=0,则b即为两数的最大公约数。

4.若r≠0,则用b除以r,得到新的余数。

5.重复步骤2和3,直到余数为0。

例如,计算48和18的最大公约数:48 ÷ 18 = 2 余数1218 ÷ 12 = 1 余数612 ÷ 6 = 2 余数0因此,最大公约数为6。

三、更相减损术更相减损术是中国古代数学家发明的一种计算最大公约数的方法。

具体步骤如下:1.将两个数a和b进行比较,使a≥b。

2.用a减去b,得到差值c。

3.若c等于b,则b即为两数的最大公约数。

4.若c大于b,则用c减去b,得到新的差值。

5.重复步骤2和3,直到差值等于b。

例如,计算48和18的最大公约数:48 - 18 = 3030 - 18 = 1218 - 12 = 6因此,最大公约数为6。

四、使用编程语言计算最大公约数在许多编程语言中,都有现成的函数或方法可以计算最大公约数。

例如,在Python中,可以使用math模块的gcd函数计算最大公约数:```pythonimport matha = 48b = 18print(math.gcd(a, b)) # 输出结果为6```总结:最大公约数的计算方法有多种,包括列举法、辗转相除法、更相减损术等。

求解最大公约数问题

求解最大公约数问题

求解最大公约数问题最大公约数(Greatest Common Divisor, 简称GCD)是数论中一个重要的概念,用来表示两个或多个整数中最大的能够同时整除它们的正整数。

在数学和计算机科学领域,求解最大公约数问题有着广泛的应用,包括简化分数、判断两个数是否互质、简化矩阵等。

求解最大公约数的问题可以使用多种方法和算法来解决,下面将介绍其中的几种常用算法。

一、欧几里得算法(辗转相除法)欧几里得算法是求解最大公约数问题最常用的算法之一。

该算法基于一个简单的原理:两个整数a和b(a > b)的最大公约数等于a除以b的余数c和b之间的最大公约数。

具体步骤如下:1. 将较大的数a除以较小的数b,得到商q和余数c;2. 如果余数c等于0,则b即为最大公约数;3. 如果余数c不等于0,则将b赋值给a,将余数c赋值给b,然后继续进行第1步。

欧几里得算法的复杂度较低,适用于大部分正整数的最大公约数求解。

二、更相减损术法更相减损术法也是一种古老的求解最大公约数的方法。

该方法基于一个简单的原理:两个整数a和b(a > b)的最大公约数等于a减去b的差d和b之间的最大公约数。

具体步骤如下:1. 如果a等于b,则a即为最大公约数;2. 如果a不等于b,则计算两者之间的差d,将较大数赋值给a,将差d赋值给b,然后继续进行第1步。

更相减损术法的应用范围有限,对于较大的数值可能会出现较大的差值,导致算法效率降低。

三、辗转相减法和移位结合辗转相减法和移位结合是一种结合了欧几里得算法和更相减损术法的改进算法。

该算法的主要思想是在更相减损术法的基础上添加了位移操作,以减少差值的大小。

具体步骤如下:1. 如果a和b均为偶数,则a和b同时右移一位,继续进行该步骤,直到其中一个数为奇数;2. 如果a为偶数、b为奇数,则将a右移一位,继续进行该步骤,直到a为奇数;3. 如果b为偶数、a为奇数,则将b右移一位,继续进行该步骤,直到b为奇数;4. 此时,再使用更相减损术法计算a和b的差值d,并替换其中较大的数为d;5. 重复上述步骤,直到a和b相等,该相等的值即为最大公约数。

总结求最大公约数的方法及原理

总结求最大公约数的方法及原理

总结求最大公约数的方法及原理一、最大公约数及其意义最大公约数,也称为最大公因数或最大公因式,是两个或多个整数共有约数中最大的一个。

求最大公约数是数学中的一个基本问题,它在许多领域都有广泛的应用,如代数、几何、组合数学等。

同时,最大公约数也是算法设计中的重要概念,例如在计算复杂度、数据压缩等领域都有涉及。

二、最大公约数的求解方法求最大公约数的方法有很多种,以下是其中一些常见的方法:1.辗转相除法(欧几里得算法)辗转相除法是一种古老而基础的求最大公约数的方法,基于欧几里得算法。

该算法的基本思想是,用较大的数除以较小的数,然后用除数去除下余数,如此反复,直到余数为0,此时除数即为所求的最大公约数。

2.辗转相减法辗转相减法是一种求两个整数的最大公约数的算法。

该算法的基本思想是,用较大的数减去较小的数,然后将差值加到较小的数上,如此反复,直到两数相等,此时相等的数即为所求的最大公约数。

3.扩展欧几里得算法扩展欧几里得算法是基于欧几里得算法的一种求整数方程解的算法。

该算法可以求出给定整数方程的整数解,同时也能够求出该方程的最大公约数。

扩展欧几里得算法的基本思想是,通过递归地求解欧几里得算法来得到整系数方程的解,并将求解过程中的除法操作替换为线性方程组求解。

4.分数分解法分数分解法是一种通过分数分解来求两个整数最大公约数的算法。

该算法的基本思想是,将两个整数表示为分数的形式,然后对这些分数进行分解和约分,最后得到的分数即为所求的最大公约数。

分数分解法的优点是可以在一定程度上处理大整数,但对于非常大的整数仍然难以处理。

5.质因数分解法质因数分解法是一种求两个整数最大公约数的算法。

该算法的基本思想是,将两个整数分别进行质因数分解,然后找出其中的公共质因数,最后将公共质因数相乘即可得到最大公约数。

质因数分解法的优点是精度高、运算速度快,适用于大整数的计算。

但该方法也有一定的复杂性,需要耗费较多的时间和空间资源。

三、最大公约数的应用场景最大公约数的应用场景非常广泛,以下是其中一些常见的应用场景:1.密码学:在密码学中,最大公约数是用于实现加密和解密的数学工具之一。

最大公约数的求解和应用

最大公约数的求解和应用

最大公约数的求解和应用最大公约数(Greatest Common Divisor,简称GCD),指的是两个或多个整数中能够同时被整除的最大正整数。

它是数论中的重要概念,在计算机科学、密码学、代数等领域有着广泛的应用。

本文将介绍最大公约数的求解方法以及其在实际应用中的作用。

一、欧几里得算法求解最大公约数欧几里得算法,也称辗转相除法,是一种简便高效的求解最大公约数的方法。

它的基本思想是利用两个整数的除法操作,将大数不断除以小数,直到余数为0,此时的除数即为最大公约数。

例如,对于整数a和b,假设a > b,我们可以按照以下步骤来求解最大公约数:1. 用a除以b,得到商q和余数r(a = bq + r);2. 若r等于0,则b即为最大公约数;3. 若r不等于0,则令a = b,b = r,再次执行步骤1。

通过不断重复以上步骤,最终我们可以得到最大公约数。

二、最大公约数的应用1. 约简分数最大公约数在约简分数中有着重要的应用。

任意一个分数都可以通过除以其分子分母的最大公约数来约简,使得分数的表示更加简洁。

例如,对于分数8/12,我们可以求得其最大公约数为4,将分子分母都除以4得到1/3,即约简后的分数。

2. 寻找最小公倍数最小公倍数(Least Common Multiple,简称LCM)是指两个或多个整数中能够同时整除的最小正整数。

最大公约数与最小公倍数之间有一个重要的性质:两个整数的最大公约数乘以最小公倍数等于这两个整数的乘积。

因此,在求解最小公倍数时,可以先求解最大公约数,再利用该性质进行计算。

例如,对于整数3和4,它们的最大公约数为1,根据性质,我们可以得到它们的最小公倍数为3 * 4 = 12。

3. 密码学中的应用最大公约数在密码学中的应用是基于模运算。

在RSA公钥加密算法中,生成密钥的过程中需要选择两个大素数p和q,并计算它们的最大公约数。

通过求解最大公约数,可以判断两个素数是否互质,从而确保算法的安全性。

求最大公约数的三种方法

求最大公约数的三种方法

求最大公约数的三种方法最大公约数是指在两个或多个整数中,能够同时被整除的最大正整数。

在生活中,常常需要求两个数的最大公约数,而计算最大公约数有多种方法,下面将介绍最常用的三种方法。

方法一:质因数分解法这是一种经典的求最大公约数的方法,它的核心思想是通过将两个数分别分解成质因数,然后将它们的公共质因数提出来,最后再将这些公共质因数相乘,得到的结果就是最大公约数。

举个例子,假设要求65和78的最大公约数,首先分别分解成质因数:65=5×1378=2×3×13然后将它们的公共质因数提出来,即13,因此它们的最大公约数就是13。

这种方法的优点在于,它的计算过程简单、直观,而且适用于所有的正整数。

但是,对于较大的数字,质因数分解的时间成本较高,所以这种方法的效率较低。

方法二:辗转相除法辗转相除法是一种古老的求最大公约数的方法,其原理是通过连续地做减法和取模运算,将两个数逐渐缩小为它们的最大公约数。

具体的计算步骤如下,假设要求65和78的最大公约数:1. 用较大数除以较小数,并将余数作为新的被除数;2. 将上一步的余数和原来的被除数继续做取模运算,直到余数为0为止;3. 最后被除数就是最大公约数。

根据上面的例子,可以得到以下计算过程:78÷65=1 (13)65÷13=5 0因此,65和78的最大公约数就是13。

这种方法的优点在于,它的计算速度较快,尤其是对于大数的计算。

但是,其计算过程较为抽象,不太容易理解。

综上,无论使用何种方法求最大公约数,都应根据实际问题的情况选择合适的方法,以达到计算效率和准确度的最佳平衡点。

掌握最大公约数与最小公倍数的计算方法

掌握最大公约数与最小公倍数的计算方法

掌握最大公约数与最小公倍数的计算方法最大公约数(Greatest Common Divisor, GCD)和最小公倍数(Least Common Multiple, LCM)是数学中两个重要的概念。

掌握它们的计算方法对于解决一些实际问题和数学推理有着重要的作用。

本文将介绍最大公约数与最小公倍数的定义、计算方法和应用。

一、最大公约数的定义与计算方法最大公约数是指两个或多个整数中能够整除所有这些整数的最大的正整数。

例如,对于整数12和18,它们的最大公约数是6。

常用的计算最大公约数的方法有以下几种。

1. 辗转相除法:将两个整数中较大的数除以较小的数,将余数作为新的被除数,将原先的除数作为新的除数,重复这个步骤,直到余数为0时,最后的除数就是最大公约数。

2. 公因数法:列举出两个整数的所有因数,找出它们的公共因数中的最大的一个就是最大公约数。

3. 质因数分解法:将两个整数分别用质因数相乘的形式表示,然后取两个数中所有质因数的交集,将交集中的质因数相乘得到的数就是最大公约数。

以上三种方法都能够有效地计算出最大公约数,具体使用哪种方法可以根据实际情况选择。

二、最小公倍数的定义与计算方法最小公倍数是指两个或多个整数中能够被这些整数整除的最小的正整数。

例如,对于整数3和5,它们的最小公倍数是15。

最小公倍数的计算方法主要有以下几种。

1. 分解质因数法:将两个整数分别用质因数相乘的形式表示,取两者质因数的并集,将并集中的质因数相乘得到的数就是最小公倍数。

2. 公倍数法:列举出两个整数的倍数,找出它们的公共倍数中的最小的一个就是最小公倍数。

与计算最大公约数类似,计算最小公倍数时也可以根据实际情况选择合适的方法。

三、最大公约数与最小公倍数的应用最大公约数与最小公倍数的应用广泛。

在计算中,常常需要将分数进行化简,这就需要用到最大公约数。

最大公约数还可以用于简化分数运算、求解同余方程等。

最小公倍数在数学中的应用较多,如求解车轮转速、计算周期性事件的时间等。

求最大公因数最快方法

求最大公因数最快方法

求最大公因数最快方法最大公因数(GCD)是指两个或多个整数中最大的公约数。

求最大公因数的方法有很多种,包括穷举法、辗转相除法、质因数分解法、更相减损法等。

下面将分别介绍这些方法的原理和优劣势,以及一些其他方法。

1. 穷举法:穷举法是最直观的方法,即对两个整数的所有因数进行穷举,找出它们的公约数中最大的一个。

这个方法的优势是简单易理解,适用于较小的整数。

但当整数较大时,穷举的范围较大,速度较慢。

2. 辗转相除法(欧几里得算法):辗转相除法利用了两个整数之间的整除关系,即两个整数a和b(a>b),它们的最大公约数等于b与a%b的最大公约数。

通过不断地将较大数与余数计算最大公约数,直到余数为0,则较小的数即为最大公约数。

这个方法的优势在于计算速度较快,适用于大整数。

但当两个整数相差很大时,此方法可能效率较低。

3. 更相减损法:更相减损法是一种辗转相减的方法,它使用的原理是任何一个奇数减去另一个奇数的差是偶数,一个奇数减去一个偶数的差是奇数。

因此,我们可以不断地将两个整数中较大的减去较小的,直到两个整数相等,这时的整数即为最大公约数。

这个方法的优势在于可以减少除法运算,但当两个整数相差很大时,辗转相减的次数较多,效率较低。

4. 质因数分解法:质因数分解法是将两个整数进行质因数分解,然后找出它们公共的质因数,再将这些质因数相乘。

这个方法的优势在于可以避免不必要的除法运算,尤其对于较大的整数来说,计算速度较快。

但它的劣势在于复杂度较高,需要先将两个整数进行质因数分解。

除了上述传统的方法,还有一些更高效的方法,如辗转相减法与移位法相结合的二进制算法和Stein算法等。

这些方法主要基于更相减法和移位运算的思想,利用位运算和递归来提高计算速度。

它们的优势在于减少了运算次数和数据规模,适用于非常大的整数。

总而言之,要确定最大公因数最快的方法,需要根据具体情况选择合适的算法。

对于小整数,穷举法和辗转相除法都是简单有效的选择;对于大整数,质因数分解法和二进制算法等更高级的方法能够提供更快的计算速度。

求最大公约数了解最大公约数的求解方法

求最大公约数了解最大公约数的求解方法

求最大公约数了解最大公约数的求解方法最大公约数是指两个或多个数中能够同时整除的最大的正整数。

在数学中,最大公约数的求解方法有欧几里得算法、质因数分解法和辗转相除法等几种常见方法。

下面将逐一介绍这些方法。

一、欧几里得算法欧几里得算法,也称为辗转相除法,是一种用于求解最大公约数的经典算法。

该算法的基本思想是根据两个数的除法余数的性质来进行求解。

1. 欧几里得算法的步骤:a. 取两个整数a和b(a > b);b. 当b不等于0时,用a除以b,得到余数r;c. 若r等于0,则b即为最大公约数;d. 若r不等于0,则令a等于b,b等于r,然后返回步骤b。

2. 示例:假设我们要求解135和225的最大公约数。

a. 根据步骤1,取a=225,b=135;b. 根据步骤2b,计算225除以135的余数,得到r=90;c. 根据步骤2d,令a=135,b=90;d. 根据步骤2b,计算135除以90的余数,得到r=45;e. 根据步骤2d,令a=90,b=45;f. 根据步骤2b,计算90除以45的余数,得到r=0;g. 根据步骤2c,最大公约数为45。

二、质因数分解法质因数分解法是一种将待求最大公约数的两个数分别进行质因数分解的方法,然后找出它们的公共质因数的乘积。

1. 质因数分解法的步骤:a. 将待求最大公约数的两个数分别进行质因数分解;b. 找出它们的公共质因数的乘积。

2. 示例:假设我们要求解48和60的最大公约数。

a. 将48进行质因数分解,得到2^4 * 3;b. 将60进行质因数分解,得到2^2 * 3 * 5;c. 公共质因数的乘积为2^2 * 3 = 12,即为最大公约数。

三、辗转相除法辗转相除法是欧几里得算法的一种变形方法,它可以用于求解两个数的最大公约数。

1. 辗转相除法的步骤:a. 取两个整数a和b(a > b);b. 用a除以b得到商q和余数r;c. 如果r等于0,则b即为最大公约数;d. 如果r不等于0,则令a=b,b=r,并返回步骤b。

约数的最大公约数

约数的最大公约数

约数的最大公约数1. 引言在数学中,约数是指能够整除一个数的所有整数,而最大公约数是指两个或多个整数共有的约数中最大的一个。

本文将探讨约数的最大公约数的概念、性质和计算方法,并给出一些实际应用的例子。

2. 约数和最大公约数的定义2.1 约数的定义给定一个整数a,如果存在整数b使得b能够整除a,那么b就是a的约数。

换句话说,如果a能够被b整除,那么b是a的约数。

例如,整数12的约数有1、2、3、4、6和12。

2.2 最大公约数的定义给定两个整数a和b,它们的最大公约数是能够同时整除a和b的最大整数。

最大公约数通常用符号gcd(a, b)表示,其中gcd代表”最大公约数”,a和b是要求最大公约数的两个整数。

例如,整数12和18的最大公约数是6,可以表示为gcd(12, 18) = 6。

3. 最大公约数的性质最大公约数具有一些重要的性质,这些性质对于计算最大公约数和解决实际问题非常有用。

3.1 互质性如果两个整数a和b的最大公约数是1,那么它们被称为互质数(又称互素)。

互质数的一个重要性质是,它们没有除了1以外的公约数。

这意味着互质数的最大公约数只能是1。

例如,整数12和35是互质数,因为它们的最大公约数是1。

3.2 最大公约数的整除性对于任意三个整数a、b和c,如果a能够整除b,那么gcd(a, b)也能够整除c。

这个性质对于计算最大公约数非常有用,因为它可以帮助我们简化问题。

我们可以先计算a和b的最大公约数,然后再用最大公约数来计算其他的约数。

3.3 辗转相除法辗转相除法是一种常用的计算最大公约数的方法。

它基于以下观察:如果a能够整除b,那么a也能够整除a和b的余数。

具体的计算步骤如下: 1. 计算a除以b的余数,记为r。

2. 如果r等于0,则b就是最大公约数。

3. 如果r不等于0,则将b赋值给a,将r赋值给b,然后重复步骤1。

例如,计算gcd(12, 18)的过程如下: 1. 18除以12的余数是6,记为r。

欧几里得算法实现、正确性证明及时间复杂度分析

欧几里得算法实现、正确性证明及时间复杂度分析

欧⼏⾥得算法实现、正确性证明及时间复杂度分析求最⼤公约数的最常⽤的算法是欧⼏⾥得算法,也称为辗转相除法。

问题定义为求i和j的最⼤公约数gcd(i,j),其中i和j是整数,不妨设i>j。

算法可以递归的表⽰:1.如果j能整除i,那么gcd(i,j)=j;2.j不能整除i,令r=i%j,那么gcd(i,j)=gcd(j,r). 上⾯的算法对于i<j的情况也是可以的,实际上是做了⼀次交换。

使⽤C语⾔实现:int gcd(int i, int j){int r = i % j;return r == 0 ? j : gcd(j, r);}算法正确性分析下⾯⼀步⼀步的切⼊在证明之前先看⼀个说明:对于两个数i=md,j=nd.i、j的最⼤公约数是d的充要条件是:m和n互质。

再看另⼀个说明:如果m和n互质,那么(m-kn)和n也互质。

这个可以⽤反正法:假设(m-kn)和n不互质,那么存在⼀个因⼦e,使得(m-kn)=en。

那么m=(k+e)n,这与m、n互质的题⽬条件违背,所以假设不成⽴。

则(m-kn)和n也互质。

算法的步骤1,显然是成⽴的,因为这就是最⼤公约数的定义。

算法的步骤2:其实算法证明的⽬标是r=i%j != 0时,gcd(i,j)=gcd(j,r)。

根据已知条件,设d是i、j的最⼤公约数,则i=md,j=nd,其中m、n是互质的。

(如果m、n不互质,d就不是最⼤公约数)(现在要找的是gcd(j,r)的最⼤公约是也是d,那么就要⽤d去表⽰r,证明这个表达式的系数和n互质,那么d就是r和j的最⼤公约数)接着上⾯的说,由于r=i%j,则i=kj+r其中k>=1,k=[m/n],带⼊上⾯的等式:md=kndr,所以r=(m-kn)d,⼜因为j=nd,n和(m-kn)互质,所以d是j、r的最⼤公约数。

算法的步骤1,显然成⽴(最⼤公约数定义).关键是要证明步骤2.设d是i和j的最⼤公约数,那么i=md,j=nd,m和n互质(否则d不是最⼤公约数).由r=i%j可以得到i=kj+r,k=⌊m/n⌋,k≥1(我们前⾯假设过i>j).把i=md,j=nd代⼊得到md=knd+r那么r=(m-kn)dm-kn和m也是互质的.所以得到d是j和r的最⼤公约数.时间复杂度分析逆着看该算法,最后的余数是0,倒数第⼆次余数是d,倒数第三次是kd,k>1…由于组成了⼀个数列,{0,d,kd,nkd+d,…}数列的n项加上n+1项,⽐n+2项要⼩,所以⽐斐波纳契数列增长的要快.我们已知斐波纳契数列增长速度是指数,那么待分析的数列也是指数增长.设欧⼏⾥得算法需要k次,那么j=O(2^k),则k=O(lg j).所以欧⼏⾥得算法求最⼤公约数的时间复杂度是对数量级的,速度⾮常快.。

快速计算最大公约数和最小公倍数的方法

快速计算最大公约数和最小公倍数的方法

快速计算最大公约数和最小公倍数的方法数学中,最大公约数和最小公倍数是两个常见的概念。

计算它们的方法可以有很多种,但是我们希望找到一种快速且高效的方法。

本文将介绍一些常用的技巧和算法,帮助你快速计算最大公约数和最小公倍数。

一、辗转相除法辗转相除法是一种常用的计算最大公约数的方法。

它基于这样一个原理:两个数的最大公约数等于其中较小数和两数的差的最大公约数。

具体步骤如下:1. 假设两个数为a和b,其中a > b。

2. 用a除以b,得到余数r。

3. 如果r为0,则b即为最大公约数。

4. 如果r不为0,则用b除以r,再得到余数r1。

5. 重复上述步骤,直到余数为0,此时的除数即为最大公约数。

例如,计算36和48的最大公约数:36 ÷ 48 = 0 (36)48 ÷ 36 = 1 (12)36 ÷ 12 = 3 0最大公约数为12。

辗转相除法的优点是简单易懂,计算过程较快。

但是当两个数相差较大时,计算次数可能较多,效率会稍低。

二、质因数分解法质因数分解法是一种常用的计算最大公约数和最小公倍数的方法。

它基于这样一个原理:两个数的最大公约数等于它们的公共质因数的乘积,而最小公倍数等于它们的所有质因数的乘积。

具体步骤如下:1. 对两个数进行质因数分解,得到它们的质因数表达式。

2. 找出两个数的公共质因数,并将其乘积作为最大公约数。

3. 将两个数的所有质因数相乘,得到最小公倍数。

例如,计算36和48的最大公约数和最小公倍数:36 = 2^2 × 3^248 = 2^4 × 3公共质因数为2^2 × 3 = 12,最大公约数为12。

最小公倍数为2^4 × 3^2 = 144。

质因数分解法的优点是能够准确地计算最大公约数和最小公倍数,适用于各种数值大小的计算。

但是对于较大的数,质因数分解可能会比较耗时。

三、辗转相减法辗转相减法是一种计算最大公约数的方法。

递归求最大公约数的时间复杂度

递归求最大公约数的时间复杂度

递归求最大公约数的时间复杂度
一、什么是递归求最大公约数?
递归求最大公约数是指在计算两个数的最大公约数时,通过反复调用一个函数自身来实现的。

二、递归求最大公约数的原理
递归求最大公约数的原理可以通过欧几里得算法来解释。

欧几里得算法又称为辗转相除法,它的基本思想是:用较大数除以较小数,再用余数去除除数,如此反复,直到余数为零为止。

此时,除数就是两个数的最大公约数。

三、递归求最大公约数的代码实现
```
def gcd(a, b):
if b == 0:
return a
else:
return gcd(b, a % b)
```
四、递归求最大公约数的时间复杂度分析
递归求最大公约数的时间复杂度可以通过递推公式来计算。

设T(n)表示计算两个数的最大公约数的时间复杂度,则有:
T(n) = T(n mod m) + O(1)
其中,n为较大的数,m为较小的数。

根据递推公式,可以得出递归求最大公约数的时间复杂度为O(log n),其中n为两个数中较大的那个数。

这是因为每次递归都会将问题的规模缩小一半,因此递归的层数为O(log n)。

而每一层递归的时间复杂度为O(1),因此总的时间复杂度为O(log n)。

通过分析可得,递归求最大公约数算法的时间复杂度是比较优秀的,适合对时间和空间要求较高的应用场景。

同时,它的代码实现也比较简洁,具有一定的可读性和可维护性。

综上所述,递归求最大公约数算法是一种比较优秀的求解最大公约数问题的方法,具有较好的时间复杂度和代码实现简洁等优点。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

理工大学信息工程与自动化学院学生实验报告(2011 —2012 学年第 1 学期)课程名称:算法设计与分析开课实验室:信自楼机房444 2011 年10月 12日一、上机目的及容1.上机容求两个自然数m和n的最大公约数。

2.上机目的(1)复习数据结构课程的相关知识,实现课程间的平滑过渡;(2)掌握并应用算法的数学分析和后验分析方法;(3)理解这样一个观点:不同的算法能够解决相同的问题,这些算法的解题思路不同,复杂程度不同,解题效率也不同。

二、实验原理及基本技术路线图(方框原理图或程序流程图)(1)至少设计出三个版本的求最大公约数算法;(2)对所设计的算法采用大O符号进行时间复杂性分析;(3)上机实现算法,并用计数法和计时法分别测算算法的运行时间;(4)通过分析对比,得出自己的结论。

三、所用仪器、材料(设备名称、型号、规格等或使用软件)1台PC及VISUAL C++6.0软件四、实验方法、步骤(或:程序代码或操作过程)实验采用三种方法求最大公约数1、连续整数检测法。

根据实现提示写代码并分析代码的时间复杂度:方法一:int f1(int m,int n){int t;if(m>n)t=n;else t=m;while(t){if(m%t==0&&n%t==0)break;else t=t-1;}return t;}根据代码考虑最坏情况他们的最大公约数是1,循环做了t-1次,最好情况是只做了1次,可以得出O(n)=n/2;方法二:int f2(int m,int n){int r;r=m%n;while(r!=0){m=n;n=r;r=m%n;}return n;}根据代码辗转相除得到欧几里得的O(n)= log n方法三:int f3(int m,int n){int i=2,j=0,h=0;int a[N],b[N],c[N];while(i<n){if(n%i==0){j++;a[j]=i;n=n/i;}else i++;}int u;u=j;while(i<=j){//printf("%d ",a[i]);i++;}i=2;j=0;while(i<m){if(m%i==0){j++;b[j]=i;m=m/i;}else i++;}j++;b[j]=m;i=1;while(i<=j){//printf("%d ",b[i]);i++;}int k=1;for(i=1;i<=j;i++){for(k=1;k<=u;k++){if(b[i]==a[k]){h++;c[h]=a[k];//printf("%d ",c[h]);a[k]=a[k+1];break;}}}k=1;while(h>1){k=k*c[h]*c[h-1];h=h-2;k=k*c[1];return k;}else return k;}根据代码分解质因子算法O(n)=n2+n/2为了计算每种算法运行的次数所用的时间,我将代码稍加改动添加代码如下:其中计数器采用的是没做一次循环就加1;计时器是记住开始时间和结束时间,用结束时间减开始时间。

#include"iostream.h"#include"stdio.h"#include"stdlib.h"#include"time.h"#define N 100int w,w2,w3;//用于计数int f1(int m,int n){int t;if(m>n)t=n;else t=m;while(t){if(m%t==0&&n%t==0)break;else t=t-1;w++;}return t;}int f2(int m,int n){int r;r=m%n;w2=1;while(r!=0){m=n;n=r;r=m%n;w2++;}return n;}int f3(int m,int n){while(i<n){if(n%i==0){j++;a[j]=i;n=n/i;w3++;}else{i++;w3++;}}j++;a[j]=n;i=1;int u;u=j;while(i<=j){//printf("%d ",a[i]); i++;w3++;}//printf("\n");i=2;j=0;while(i<m){if(m%i==0){j++;b[j]=i;m=m/i;w3++;}else{i++;w3++;}}j++;b[j]=m;i=1;//printf("%d ",b[i]);i++;w3++;}int k=1;for(i=1;i<=j;i++){for(k=1;k<=u;k++){if(b[i]==a[k]){w3++;h++;c[h]=a[k];//printf("\n%d ",c[h]);a[k]=a[k+1];break;}}}k=1;while(h>1){k=k*c[h]*c[h-1];h=h-2;w3++;}if(h==1){k=k*c[1];return k;}else return k;}int main(void){int m,n;printf(" 请输入m,n :\n");scanf("%d%d",&m,&n);int k;k=f1(m,n);printf(" 方法一最大公约数为:%d\n",k);k=f2(m,n);printf(" 方法二最大公约数为:%d\n",k);printf(" 方法三最大公约数为:%d\n",k);printf("\n--------------------\n");printf("\n计数器显示结果:\n\n\n");printf("方法一:%d \n",w2);printf("方法二:%d \n",w);printf("方法三:%d \n",w3);printf("\n--------------------\n");float a,i;clock_t start,finish;double usetime;i=0;start= clock();while (i<1000000){f1(m,n);i++;}finish=clock();usetime= finish-start;printf(" 方法一用时%.f*10^(-6) 豪秒\n", usetime); i=0;start= clock();while (i<1000000){f2(m,n);i++;}finish=clock();usetime= finish-start;printf(" 方法二用时%.f*10^(-6) 豪秒\n", usetime); i=0;start= clock();while (i<1000000){f3(m,n);i++;}finish=clock();usetime= finish-start;五、实验过程原始记录( 测试数据、图表、计算等)请给出各个操作步骤的截图和说明;三种算法得到结果验证结果:计数器:我想到的是做一次循环就加一计算算法运行时间结果:在计算时间过程中因为计算机的运算速度很快,所以我利用了循环把时间精确得到10-6毫秒六、实验结果、分析和结论(误差分析与数据处理、成果总结等。

其中,绘制曲线图时必须用计算纸或程序运行结果、改进、收获)请结合实验的结果分析算法原理;在实验中遇到了些什么问题,如何解决;有什么收获等;在本次实验中代码是独自完成的,一开始我感觉这个代码最多半小时就可以完成,但是第三个算法的时候我分析了好久才写出来,在计算三种方法运行时间的时候,我一开始只精确到毫秒(ms),计算结果都是零,后面我写了一个循环调试才发现是我的精确度还在不够,所以我想到了计算算法执行了1000000次之后所用的时间,然后再求平均每次执行的时间。

结果分析:从前面的复杂度O(n)的出欧几里得算法的是最优算法,连续整除法其次,最复杂的是分解质因数算法,再从代码运行的计数器和计算的时间来看结果恰好和前面的复杂度得到的结果一致,所以的出结论:欧几里得算法最优。

从这次实验的结果我了解到了算法的优与劣的差别,虽然得到的是同样的结果,但是需要的时间和资源却相差很大,这提示我们在以后写算法的时候要找出最优算法。

可见算法分析与设计课程的对计编程的人来说是多么的重要,在以后写程序过程中要时刻提醒自己找最优算法,当然得先学会O(n)的分析。

注:教师必须按照上述各项容严格要求,认真批改和评定学生成绩。

相关文档
最新文档