国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

C語言 多種方法求最大公因數(shù)和最小公倍數(shù)

這篇具有很好參考價值的文章主要介紹了C語言 多種方法求最大公因數(shù)和最小公倍數(shù)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

最大公約數(shù):指能夠整除多個整數(shù)的最大正整數(shù),而多個整數(shù)不能都為零。

最小公倍數(shù):兩個或多個整數(shù)公有的倍數(shù)叫做它們的公倍數(shù),其中除0以外最小的一個公倍數(shù)就叫做這幾個整數(shù)的最小公倍數(shù)。

求最小公倍數(shù)的算法:

最小公倍數(shù) = 兩個整數(shù)的乘積 / 最大公因數(shù)

求最大公約數(shù)的算法:

第一種方法:輾轉相除法

有兩個整數(shù)a和b:

1. a % b ==temp;

2. 若temp = 0;那么b就是最大公約數(shù)。

3. 若temp ≠ 0;則a = b;b = temp;繼續(xù)進行a % b 操作。

eg:求25和15的最大公約數(shù),其過程為:

25 % 15 余 10 ; 15 % 10 余 5 ; 10 % 5 余 0 。因此5即為最大公約數(shù)

#include<stdio.h>
int main()
{
    int a  , b  , temp;
    printf("put in a and b : ");
    scanf("%d %d",&a,&b);
    int nul = a * b;
    
    while (a * b != 0)
    {
        temp = a % b;
        a = b;
        b = temp;
    }
    printf(" max = %d:",a);
    printf(" min = %d:", (nul / a)  );
    return 0;
}  
put in a and b : 25 15
 max = 5: min = 75:

第二種方法:相減法

取兩個整數(shù)a、b:

1. 若a > b,則 a = a - b;

2. 若a < b,則 b = b - a;

3. 若 a = b,則 a(b)即為兩數(shù)的最大公約數(shù)

4.若 a ≠ b,則繼續(xù)執(zhí)行第一步操作。

eg:求25和15的最大公約數(shù),其過程為:

25 - 15 = 10(15 > 10);15 - 10 = 5(10 > 5);

10 - 5 = 5(5 == 5)

因此,25 和15的最大公約數(shù)為5。

代碼如下:

#include<stdio.h>
int main()
{
    int a , b , m , n;
    printf("put in a and b:");
    scanf("%d %d", &a, &b);
    m = a;
    n = b;
    while (a != b)
    {
        if(a > b)
        {
            a = a - b;
        }
        else
        {
            b = b - a;
        }
    }
    printf("max = %d\n", a);
    printf("min = %d",(m * n)/a);
    return 0;
}

運行結果展示:

put in a and b:25 15
max = 5
min = 75

第三種方法:窮舉法

有兩個整數(shù)a和b:

1. 令 i = 1,

2. 如果 a,b能同時被i整除,則h = i;

3. i++;

4. 若 i <= a(b),則繼續(xù)執(zhí)行第2步操作;

5. 若i > a(b),當 i = a(b)時,窮舉結束,則此時h即為最大公約數(shù)。

代碼如下

#include<stdio.h>
int main ()
{
    int a , b , m , n , i , h;
    printf("put in a and b:");
    scanf("%d %d", &a, &b);
    m = a;
    n = b;
    for( i = 1; i <= a; i ++)
    {
        if( a % i == 0 && b % i == 0)
        {
            h = i;
        }
    }
    printf("max = %d\n", h);
    printf("min = %d",(m * n) / h);
    return 0;
}

運行結果展示:文章來源地址http://www.zghlxwxcb.cn/news/detail-452360.html

put in a and b:25 15
max = 5
min = 75

到了這里,關于C語言 多種方法求最大公因數(shù)和最小公倍數(shù)的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉載,請注明出處: 如若內容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • 【C語言】求最大公約數(shù)和最小公倍數(shù)

    【C語言】求最大公約數(shù)和最小公倍數(shù)

    方法一:利用 定義法 求最大公因數(shù)和最小公倍數(shù) 方法二:最小公倍數(shù)求法同上, 最大公約數(shù)方法不同 方法一方法二的結果示例如下 ? 方法三:利用 輾轉相除法 求最大公約數(shù)和最小公倍數(shù) 法(1)結果示例如下: ?法(2)示例結果如下: ?以上就是用C語言循環(huán)和循環(huán)之前的

    2024年02月07日
    瀏覽(94)
  • 【C語言】兩個整數(shù)最大公約數(shù)和最小公倍數(shù)

    輸入兩個整數(shù),求這兩個數(shù)的最大公約數(shù)和最小公倍數(shù)。 第一種求法(輾轉相除法)這個方法代碼較潔簡,我也比較推薦就是剛開始有點比較難了解。 首先,來看看怎么求最大公約數(shù),求最大公約數(shù)需要用到 歐幾里得算法 ,也稱為輾轉相除法。算法就是用兩數(shù)中較大的數(shù)

    2024年02月04日
    瀏覽(26)
  • 【C語言】一篇博客帶你弄懂最大公約數(shù)和最小公倍數(shù)

    【C語言】一篇博客帶你弄懂最大公約數(shù)和最小公倍數(shù)

    我們在C語言的學習中,經(jīng)常會遇到這樣一些數(shù)學題目,良好掌握這些題目有利于我們理解和學習C語言,話不多說,直接進入主題 最大公約數(shù): 首先我們舉個例子,比如12 和16,12的約數(shù)有(1,2 ,3,4,6,12),16的約數(shù)有(1,2,4,8,16)公約數(shù)就是兩個數(shù)共同的約數(shù),(1,2,4)而公約數(shù)

    2024年02月04日
    瀏覽(17)
  • C++求最大公約數(shù)和最小公倍數(shù)的方法

    每次遇到最大公約數(shù)和最小公倍數(shù)時總是忘記,這里總結了兩種求最大公約數(shù)和最小公倍數(shù)的方法。 歐幾里得算法是求解兩個數(shù)的最大公約數(shù)的一種常用方法。該算法基于以下原理:兩個整數(shù)的最大公約數(shù)等于其中較小數(shù)和兩數(shù)的余數(shù)之間的最大公約數(shù)。可以通過遞歸調用該

    2024年02月15日
    瀏覽(25)
  • C語言——輸入兩個正整數(shù)m和n,求其最大公約數(shù)和最小公倍數(shù)

    C語言——輸入兩個正整數(shù)m和n,求其最大公約數(shù)和最小公倍數(shù)

    目錄 1.最大公約數(shù)求法 1.1輾轉相除法 1.2相減法 2.最小公倍數(shù)求法 3.代碼實現(xiàn) 4.結果展示 1.1輾轉相除法 設有兩整數(shù)a和b: a%b得余數(shù)c 若c==0,則b即為兩數(shù)的最大公約數(shù) 若c!=0,則a=b,b=c,再回去執(zhí)行第一步。 例如:求27和15的最大公約數(shù)過程為: 27÷15 余12 15÷12 余3 12÷3 余0 因

    2024年02月01日
    瀏覽(14)
  • C語言——輸入兩個正整數(shù) m 和 n。求其最大公約數(shù)和最小公倍數(shù)。

    1、首先,程序通過printf函數(shù)提示用戶輸入兩個正整數(shù)m和n,然后使用scanf函數(shù)接收用戶的輸入并將值分別存儲到變量m和n中。 2、接下來,程序進入一個for循環(huán),從1開始遍歷直至i等于較小的數(shù)(m或n),檢查當前數(shù)值i是否能同時整除m和n。如果i既能被m整除又能被n整除(即滿足

    2024年02月03日
    瀏覽(21)
  • C語言--編寫兩個函數(shù),分別求兩個整數(shù)的最大公約數(shù)和最小公倍數(shù),再主函數(shù)中輸入兩個整數(shù),調用它們后輸出結果。
  • 實驗五 C語言函數(shù)程序設計習題 (使用函數(shù)計算兩點間的距離,請編寫函數(shù)fun,使用函數(shù)輸出字符矩陣,使用函數(shù)求最大公約數(shù)和最小公倍數(shù))

    實驗五 C語言函數(shù)程序設計習題 (使用函數(shù)計算兩點間的距離,請編寫函數(shù)fun,使用函數(shù)輸出字符矩陣,使用函數(shù)求最大公約數(shù)和最小公倍數(shù))

    1. 使用函數(shù)計算兩點間的距離:給定平面任意兩點坐標(x1,y1)和(x2,y2),求這兩點之間的距離(保留2位)小數(shù)。要求定義和調用dist(x1,y1,x2,y2)計算兩點間的距離。坐標中兩點坐標之間的距離公式如下: 2. 請編寫函數(shù)fun,它的功能是計算并輸出給定整數(shù)n的所有因子(不包括1與自身)

    2024年02月04日
    瀏覽(28)
  • C語言(求最小公倍數(shù)的3種方法)

    想要解開這題目首先要了解什么是最小公倍數(shù) 最小公倍數(shù):是指能同時被a和b整除的最小正整數(shù)? 例如:14 和 6? 的最小公倍數(shù)有 42 84 126 最小的數(shù)就是最小公倍數(shù) 假設:a=6? b=18 那么最小公倍數(shù)怎么也不可能小于 18 1.先找出a和b中的最大數(shù)賦值給max,然后用 if 判斷最大數(shù)ma

    2023年04月08日
    瀏覽(25)
  • 求最小公倍數(shù)的3種方法(C語言)

    最小公倍數(shù)是什么呢?它是指能同時整除a和b的最小正整數(shù),比如,3和7的公倍數(shù)有21,42,84等,21就是最小公倍數(shù)。 下面介紹3種方法來求最小公倍數(shù)。 1.輾轉相除法:a和b的最小公倍數(shù)=a*b/(a和b的最大公約數(shù)) ?2.a和b的最小公倍數(shù),隨便拿一個數(shù),比如a,由小到大找出a的倍數(shù),

    2024年02月06日
    瀏覽(19)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包