輾轉相除法用來求兩個數(shù)的最大公約數(shù),代碼如下:

站在用戶的角度思考問題,與客戶深入溝通,找到南召網(wǎng)站設計與南召網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設計與互聯(lián)網(wǎng)技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、空間域名、網(wǎng)絡空間、企業(yè)郵箱。業(yè)務覆蓋南召地區(qū)。
#include?stdio.h
#include?stdlib.h
int?main()
{
int?a,?b,r;
scanf("%d?%d",?a,?b);
while(b!=0)//當其中一個數(shù)為0,另一個數(shù)就是兩數(shù)的最大公約數(shù)
{
r?=?a%b;
a?=?b;
b?=?r;
}
printf("Greatest?Common?Divisor:?%d\n",?a);
system("pause");
}
運行結果:
用輾轉相除法(即歐幾里得算法)求兩個正整數(shù)的最大公約數(shù)。
解析:
設兩個數(shù)m,n,假設m=n,用m除以n,求得余數(shù)q。若q為0,則m為最大公約數(shù);若q不等于0,則進行如下迭代:
m=n,n=q,即原除數(shù)變?yōu)樾碌谋怀龜?shù),原余數(shù)變?yōu)樾碌某龜?shù)重復算法,直到余數(shù)為0為止。余數(shù)為0時的除數(shù)n,即為原始m、n的最大公約數(shù)。
迭代初值:m,n的原始值;
迭代過程:q=m%n;
m=n;
n=q;
迭代條件:q!=0
例如:m=8;n=6
q=m%n(8%6==2)
m=n(m==6)
n=q(n==2)
因為:(q==2)!=0,重復算法:
q=m%n(6%2==0)
m=n(m==2)余數(shù)為0時的除數(shù)n為最大公約數(shù),n值賦給了m,所以輸出m的值
n=q(n==0)
因為:q==0 所以最大公約數(shù)為m的值
源程序:
#includestdio.h
void main()
{
int m,n,q,a,b;
printf("Enter two integers:");
scanf("%d%d",a,b);
m=a;
n=b;
if(nm)
{
int z;
z=m;m=n;n=z;//執(zhí)行算法前保證m的值比n的值大
}
do
{
q=m%n;
m=n;
n=q;
}while(q!=0);
printf("The greatest common divisor of");
printf("%d,%d is %d\n",a,b,m);
}
希望對你有所幫助!
例如用輾轉相除法求a b 最大公約數(shù)(a b誰大誰小無所謂):
int GCD( int a , int b )
{
int n=a%b;
whie(n != 0) //即: while(n)
{
a = b;
b = n;
n = a % b;
}
return b; //注意這里返回的是b 不是n
}
用輾轉相除法(即歐幾里得算法)求兩個正整數(shù)的最大公約數(shù).
解析:
設兩個數(shù)m,n,假設m=n,用m除以n,求得余數(shù)q.若q為0,則m為最大公約數(shù);若q不等于0,則進行如下迭代:
m=n,n=q,即原除數(shù)變?yōu)樾碌谋怀龜?shù),原余數(shù)變?yōu)樾碌某龜?shù)重復算法,直到余數(shù)為0為止.余數(shù)為0時的除數(shù)n,即為原始m、n的最大公約數(shù).
迭代初值:m,n的原始值;
q=m%n;
m=n;
n=q;
迭代條件:q!=0
例如:m=8;n=6
q=m%n(8%6==2)
m=n(m==6)
n=q(n==2)
因為:(q==2)!=0,重復算法:
q=m%n(6%2==0)
m=n(m==2)余數(shù)為0時的除數(shù)n為最大公約數(shù),n值賦給了m,所以輸出m的值
n=q(n==0)
因為:q==0 所以最大公約數(shù)為m的值
源程序:
#include
void main()
{
int m,n,q,a,b;
printf("Enter two integers:");
scanf("%d%d",a,b);
m=a;
n=b;
if(nm)
{
int z;
z=m;m=n;n=z;//執(zhí)行算法前保證m的值比n的值大
}
do
{
q=m%n;
m=n;
n=q;
}while(q!=0);
printf("The greatest common divisor of");
printf("%d,%d is %d\n",a,b,m);
}
希望對你有所幫助!
#include stdio.h
/*輾轉相除法函數(shù)*/
int gcd_div(int a,int b)
{
if (b == 0) {
return a;
} else {
return gcd_div(b,a % b);
}
}
/*更相減損法函數(shù)*/
int gcd_sub(int a,int b)
{
int ma,mb;
ab?(ma=a,mb=b):(ma=b,mb=a);
if (mb == 0) {
return ma;
} else {
return gcd_sub(ma-mb,mb);
}
}
int main()
{
int a = 28,b = 21;
printf("最大公約數(shù)(減法):(%d %d)%d\n",b,a,gcd_sub(b,a));
printf("最大公約數(shù)(除法):(%d %d)%d\n",b,a,gcd_div(a,b));
return 0;
}
網(wǎng)站標題:c語言輾轉相除法函數(shù),c語言的輾轉相除法
文章網(wǎng)址:http://chinadenli.net/article11/dsehodd.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、云服務器、微信小程序、外貿(mào)網(wǎng)站建設、微信公眾號、小程序開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)