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

【C語言】兩個(gè)整數(shù)最大公約數(shù)和最小公倍數(shù)

這篇具有很好參考價(jià)值的文章主要介紹了【C語言】兩個(gè)整數(shù)最大公約數(shù)和最小公倍數(shù)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

題目

輸入兩個(gè)整數(shù),求這兩個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)。

?我們先來講最大公約數(shù)

第一種求法(輾轉(zhuǎn)相除法)這個(gè)方法代碼較潔簡,我也比較推薦就是剛開始有點(diǎn)比較難了解。

首先,來看看怎么求最大公約數(shù),求最大公約數(shù)需要用到歐幾里得算法,也稱為輾轉(zhuǎn)相除法。算法就是用兩數(shù)中較大的數(shù)a除以另一個(gè)數(shù)b得出余數(shù)c,然后判斷c是否為0(意思a能夠整除b),為0則b為最大公因數(shù);反之,則把b作為a,c作為b,繼續(xù)上面的操作,直至余數(shù)為0.

翻譯一下,用個(gè)簡單的代碼輸入輸出解釋一下:

輸入18 24? (這里本來要比較兩數(shù)的大小,然后直接公式得到,但也可以省去比大小,用循環(huán))

第一次循環(huán)

a = 18? ? b = 24? ? c = a%b = 18%24 = 18?

然后將a=b? ? b=c? ? (結(jié)合第二次循環(huán),可以得出我們不需要比大小,第一次小除大,會(huì)兩值不會(huì)變,但位置反,可以直接用)

a = 24? ? b=18

第二次循環(huán)

a = 24? ? b = 18? ? c = a%b = 24%18 = 6?

然后將結(jié)果a = b? ? b =c

a =18? ? ?b=6? ? (可以靜下心來感受一下這里面值相對(duì)大小的改變)

?第三次循環(huán)

a = 18? ? b = 6? ? ?c = a%b = 18%6 = 0

c的結(jié)果等于0時(shí)循環(huán)結(jié)束。

?代碼如下

#include <stdio.h>

int main()
{
? ? int m = 0;
? ? int n = 0;
? ? int temp = 0;
? ??
? ? scanf("%d %d", &m, &n);//兩個(gè)整數(shù)

? ? while (tmp = m % n)//循環(huán),大小不對(duì),自動(dòng)換位置。
? ? {
? ? ? ? m = n;
? ? ? ? n = temp;
? ? }
? ? printf("最大公約數(shù)為:%d\n", n);
? ? return 0;
}

還有一個(gè)最直接的辦法,將所有的情況都舉出來。

思路:

兩種情況討論

1.如果大數(shù)可以整除小數(shù),那么最大公約數(shù)為小數(shù)。

2.如果不能整除小數(shù),那就找一個(gè)比較大,但時(shí)小于較小的數(shù),能被兩數(shù)同時(shí)整除的數(shù)。

代碼如下:?

#include<stdio.h>
int main()

{
?? ?int a = 0;
?? ?int b = 0;
?? ?printf("請(qǐng)輸入兩個(gè)整數(shù):");
?? ?scanf("%d%d", &a, &b);
?? ?if (a >= b)

{
?? ??? ?int i = 0;
?? ??? ?for (i = b; i >= 1; i--)

????????{
?? ??? ??? ?if (a%i == 0 && b%i == 0)

????????????????{
?? ??? ??? ??? ?printf("最大公約數(shù)為:%d\n", i);
?? ??? ??? ??? ?break;
????????????????}
????????}
}
?? ?else

{
?? ??? ?int j = 0;
?? ??? ?for (j = a; j >= 1; j--)

????????{
?? ??? ??? ?if (a%j == 0 && b%j == 0)

????????????????{
?? ??? ??? ??? ?printf("最大公約數(shù)為:%d\n", j);
?? ??? ??? ??? ?break;
? ??????????????}
? ? ? ? ?}
?}
?? ?return 0;
}

?求完最大公約數(shù),接下來求最小公倍數(shù)

根據(jù)公式法,我們可以知道兩數(shù)a和b的乘積等于它們的最大公約數(shù)和最小公倍數(shù)的積,所以最小公倍數(shù)可以通過最大公約數(shù)來求。

因?yàn)樯厦嬉呀?jīng)求完最大公約數(shù),所以可以直接用兩數(shù)相乘然后除最大公約數(shù)

代碼如下

#include<stdio.h>
int main()
{
?? ?int a, b, c, d;
?? ?
?? ?scanf("%d %d %d", &a, &b,%c);//a,b為數(shù),c為最大公約數(shù);
?? ??
?? ?d = a * b / c;
?? ?
?? ?printf("%d",c);
?}?

謝謝大家的觀看!?文章來源地址http://www.zghlxwxcb.cn/news/detail-440393.html

到了這里,關(guān)于【C語言】兩個(gè)整數(shù)最大公約數(shù)和最小公倍數(shù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

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

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

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

    C語言—最大公約數(shù)和最小公倍數(shù)

    作者主頁: paper jie的博客_CSDN博客-C語言,算法詳解領(lǐng)域博主 本文作者: 大家好,我是paper jie,感謝你閱讀本文,歡迎一建三連哦。 本文錄入于 《算法詳解》專欄,本專欄是針對(duì)于大學(xué)生,編程小白精心打造的。筆者用重金(時(shí)間和精力)打造,將算法基礎(chǔ)知識(shí)一網(wǎng)打盡,希望

    2024年02月13日
    瀏覽(24)
  • 【C語言】求最大公約數(shù)和最小公倍數(shù)

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

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

    2024年02月07日
    瀏覽(94)
  • 【c語言】—求最大公約數(shù)和最小公倍數(shù)多種方法

    目錄 一.求最大公約數(shù) 1.枚舉法求最大公約數(shù) 2.輾轉(zhuǎn)相除法 二.求最小公倍數(shù) 1.枚舉法求最小公倍數(shù) 2.簡易法 3.公式法 思路:先求兩個(gè)數(shù)中的最小值,最大公約數(shù)不可能大于兩個(gè)數(shù)的最小數(shù) 比如6和18,最大公約數(shù)就是6 再如3和9,最大公約數(shù)就是3 然后再從1開始循環(huán)遍歷到最小

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

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

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

    2024年02月04日
    瀏覽(17)
  • 最大公約數(shù)和最小公倍數(shù)問題

    等差數(shù)列 藍(lán)橋杯192 gcd問題 題目描述 數(shù)學(xué)老師給小明出了一道等差數(shù)列求和的題目。但是粗心的小明忘記了一 部分的數(shù)列,只記得其中?N?個(gè)整數(shù)。 現(xiàn)在給出這?N?個(gè)整數(shù),小明想知道包含這?N?個(gè)整數(shù)的最短的等差數(shù)列有幾項(xiàng)? 思路:求出每一項(xiàng)之差的最大公約數(shù),以這個(gè)

    2023年04月09日
    瀏覽(26)
  • C++ 最大公約數(shù)與最小公倍數(shù)

    C++ 最大公約數(shù)與最小公倍數(shù)

    (一)簡單的兩個(gè)正整數(shù)? 求 最大公約數(shù) (引入專題) 思路: 根據(jù) “歐幾里得算法”? ,即 “輾轉(zhuǎn)相除法” 原理如下: 題意: 求出? ?a? , b? 兩個(gè)正整數(shù)的最大公約數(shù) 設(shè)? k = a / b,? ?r = a % b 即? ? a = k * b + r 又設(shè)? d? 為 a 和 b 的一個(gè)公約數(shù) 那么由? r = a - k * b,? 可

    2024年02月06日
    瀏覽(20)
  • P1029 最大公約數(shù)和最小公倍數(shù)問題

    3 2 1 上題目鏈接: P1029 [NOIP2001 普及組] 最大公約數(shù)和最小公倍數(shù)問題 本小蒟蒻的原始思路就是枚舉所有范圍內(nèi)的數(shù),分別求出他們的最大公約數(shù)和最小公倍數(shù),再看是否滿足題意。 于是就有了以下一言難盡的東西(;′⌒`)↓ 皇天不負(fù)有心人,收到了2個(gè)TLE,其他全WA 自我反

    2024年02月19日
    瀏覽(24)
  • 【Python 隨練】求最大公約數(shù)和最小公倍數(shù)

    輸入兩個(gè)正整數(shù) m 和 n,求其最大公約數(shù)和最小公倍數(shù)。 在本篇博客中,我們將解決一個(gè)常見的數(shù)學(xué)問題:求兩個(gè)正整數(shù)的最大公約數(shù)和最小公倍數(shù)。我們將提供問題的解析,并給出一個(gè)完整的代碼示例來計(jì)算最大公約數(shù)和最小公倍數(shù)。 給定兩個(gè)正整數(shù)m和n,我們需要求它們

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

    每次遇到最大公約數(shù)和最小公倍數(shù)時(shí)總是忘記,這里總結(jié)了兩種求最大公約數(shù)和最小公倍數(shù)的方法。 歐幾里得算法是求解兩個(gè)數(shù)的最大公約數(shù)的一種常用方法。該算法基于以下原理:兩個(gè)整數(shù)的最大公約數(shù)等于其中較小數(shù)和兩數(shù)的余數(shù)之間的最大公約數(shù)??梢酝ㄟ^遞歸調(diào)用該

    2024年02月15日
    瀏覽(24)
  • 求其最大公約數(shù)和最小公倍數(shù),一行代碼完成

    題目:輸入兩個(gè)正整數(shù) m 和 n,求其最大公約數(shù)和最小公倍數(shù)。 求出最大公約數(shù)就行,最小公倍數(shù)用m*n除以最大公約數(shù)就行

    2024年02月05日
    瀏覽(26)

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

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

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

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包