最大公約數怎麼求算法c語言原理,最大公約數怎麼求算法c語言原理視頻

本文目錄一覽:

c語言求兩個數的最大公約數

思路:求兩個數的最大公約數使用輾轉相除法。

輾轉相除法,

又名歐幾里德算法(Euclidean

algorithm)乃求兩個正整數之最大公因子的算法。原理:兩個整數的最大公約數等於其中較小的數和兩數的差的最大公約數。

參考代碼:

#include stdio.h

int main()

{

int x,y,z;

scanf(“%d%d”,x,y);

while(x!=0)

{

z=x%y;

x=y;

y=z;

}

printf(“%d\n”,z);

return 0;

}

/*

運行結果:

6 27

3

*/

C語言程序設計如何求最大公約數

最大公約數算法:

(1)輾轉相除法

兩整數a和b:

① a%b得餘數c

② 若c=0,則b即為兩數的最大公約數,結束

③ 若c≠0,則a=b,b=c,再回去執行①

(2)相減法

兩整數a和b:

① 若ab,則a=a-b

② 若ab,則b=b-a

③ 若a=b,則a(或b)即為兩數的最大公約數,結束

④ 若a≠b,則再回去執行①

(3)窮舉法:

① i= a b中的小數

② 若a,b能同時被i整除,則i即為最大公約數,結束

③ i–,再回去執行②

c語言最大公約數的求法

最大公約數c語言編程的常用思路是:按照從大(兩個整數中較小的數)到小(到最小的整數1)的順序求出第一個能同時整除兩個整數的自然數,即為所求。

兩個數的最大公約數有可能是其中的小數,所以在按從大到小順序找尋最大公約數時,循環變量i的初值從小數n開始依次遞減,去尋找第一個能同時整除兩整數的自然數,並將其輸出。

需要注意的是,雖然判定條件是i0,但在找到第一個滿足條件的i值後,循環沒必要繼續下去,如,25和15,最大公約數是5,對於後面的4、3、2、1沒必要再去執行,但此時判定條件仍然成立,要結束循環只能藉助break語句。

具體代碼實現:

#includestdio.h

int main()

{

int m,n,temp,i;

printf(“Input mn:”);

scanf(“%d%d”,m,n);

if(mn)/*比較大小,使得m中存儲大數,n中存儲小數*/

{/*交換m和n的值*/

temp=m;

m=n;

n=temp;

}

for(i=n;i0;i–)/*按照從大到小的順序尋找滿足條件的自然數*/

if(m%i==0n%i==0)

{/*輸出滿足條件的自然數並結束循環*/

printf(“The GCD of%d and%d is:%d\n”,m,n,i);

break;

}

return 0;

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/258548.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:50
下一篇 2024-12-15 12:50

相關推薦

  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • Python實現爬樓梯算法

    本文介紹使用Python實現爬樓梯算法,該算法用於計算一個人爬n級樓梯有多少種不同的方法。 有一樓梯,小明可以一次走一步、兩步或三步。請問小明爬上第 n 級樓梯有多少種不同的爬樓梯…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Harris角點檢測算法原理與實現

    本文將從多個方面對Harris角點檢測算法進行詳細的闡述,包括算法原理、實現步驟、代碼實現等。 一、Harris角點檢測算法原理 Harris角點檢測算法是一種經典的計算機視覺算法…

    編程 2025-04-29
  • 數據結構與算法基礎青島大學PPT解析

    本文將從多個方面對數據結構與算法基礎青島大學PPT進行詳細的闡述,包括數據類型、集合類型、排序算法、字符串匹配和動態規劃等內容。通過對這些內容的解析,讀者可以更好地了解數據結構與算…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • 瘦臉算法 Python 原理與實現

    本文將從多個方面詳細闡述瘦臉算法 Python 實現的原理和方法,包括該算法的意義、流程、代碼實現、優化等內容。 一、算法意義 隨着科技的發展,瘦臉算法已經成為了人們修圖中不可缺少…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29

發表回復

登錄後才能評論