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

P1029 最大公約數(shù)和最小公倍數(shù)問題

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

3 2 1 上題目鏈接:
P1029 [NOIP2001 普及組] 最大公約數(shù)和最小公倍數(shù)問題

本小蒟蒻的原始思路就是枚舉所有范圍內(nèi)的數(shù),分別求出他們的最大公約數(shù)和最小公倍數(shù),再看是否滿足題意。

于是就有了以下一言難盡的東西(;′⌒`)↓

#include <stdio.h>

int main()
{
    int x,y,count;
    scanf("%d%d",&x,&y);
    for(int i=x;i<=y;i+=x)//i+=x是因?yàn)榍蟪鰜淼臄?shù)肯定是x的倍數(shù),所以就以x為增量了
    {
        for(int j=x;j<=y;j+=x)
        {
            int m=i,n=j,t;
            while(m%n)//求最大公約數(shù)
            {
                t=m%n;
                m=n;
                n=t;
            }
            if(n==x&&i*j==x*y)//i*j==x*y是因?yàn)樽钚」稊?shù)等于兩個(gè)數(shù)的乘積除以最大公約數(shù)
                count++;
        }
    }
    printf("%d",count);
    return 0;
}

皇天不負(fù)有心人,收到了2個(gè)TLE,其他全WA

自我反省大佬們的題解,做了以下優(yōu)化↓

#include <stdio.h>
#include <math.h>

int main()
{
    int x,y,count=0;
    scanf("%d%d",&x,&y);
    if(x==y)//特解
        count--;
    for(int i=x;i<=sqrt(x*y);i+=x)//減少循環(huán)次數(shù)
    {
        for(int j=x;j<=y;j+=x)
        {
            int m=i,n=j,t;
            while(m%n)
            {
                t=m%n;
                m=n;
                n=t;
            }
            if(n==x&&i*j==x*y)
                count+=2;//每次加2,因?yàn)閕和j倒過來又是一種情況
        }
    }
    printf("%d",count);
    return 0;
}

注:

  1. 補(bǔ)充上遺漏的特解(不然也會(huì)錯(cuò)),x=y時(shí),只會(huì)出現(xiàn)一次
  2. x=y時(shí),i=j=x=y,在此之后就都是倒過來重復(fù)的情況,所以循環(huán)到√(x*y)即可,減少了循環(huán)次數(shù)
  3. 綜上,count每次+2,特解時(shí)count-1即可

不知道為什么就能AC了,有大佬說需要用long long,不然會(huì)爆,但我沒有(⊙o⊙)?

覺得還有一個(gè)方法很好,遞歸輾轉(zhuǎn)相除求最大公約數(shù):文章來源地址http://www.zghlxwxcb.cn/news/detail-825019.html

int gcd(int n,int m)
{
    if(n%m==0)
	return m;
    else 
	return gcd(m,n%m);
}

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

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(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ù)

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

    2024年02月07日
    瀏覽(94)
  • 【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日
    瀏覽(39)
  • C++求最大公約數(shù)和最小公倍數(shù)的方法

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

    2024年02月15日
    瀏覽(25)
  • 【C語言】?jī)蓚€(gè)整數(shù)最大公約數(shù)和最小公倍數(shù)

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

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

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

    2024年02月05日
    瀏覽(26)
  • 左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)

    左手Python 右手R —— 最大公約數(shù)和最小公倍數(shù)

    ??此專欄為python與R語言對(duì)比學(xué)習(xí)的文章;以通俗易懂的小實(shí)驗(yàn),帶領(lǐng)大家深入淺出的理解兩種語言的基本語法,并用以實(shí)際場(chǎng)景!感謝大家的關(guān)注,希望對(duì)大家有所幫助。 ??“博觀而約取,厚積而薄發(fā)!”謹(jǐn)以此言,望諸君共勉 ??本文針對(duì)數(shù)學(xué)問題“ 最大公約數(shù)、最

    2023年04月21日
    瀏覽(25)
  • 【c語言】—求最大公約數(shù)和最小公倍數(shù)多種方法

    目錄 一.求最大公約數(shù) 1.枚舉法求最大公約數(shù) 2.輾轉(zhuǎn)相除法 二.求最小公倍數(shù) 1.枚舉法求最小公倍數(shù) 2.簡(jiǎn)易法 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日
    瀏覽(18)
  • 輸入兩個(gè)正整數(shù),求這兩個(gè)正整數(shù)的最大公約數(shù)和最小公倍數(shù)。

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

    一、輸入兩個(gè)正整數(shù),求這兩個(gè)正整數(shù)的最大公約數(shù)和最小公倍數(shù)。 ? ? ? ? 最大公約數(shù):1、這個(gè)數(shù)同時(shí)能被兩個(gè)整數(shù)整除,余數(shù)為0 就是公約數(shù) ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 2、只要在公約數(shù)中取最大值即可 ? ? ? ? 最小公倍數(shù):1、這個(gè)數(shù)能同時(shí)整除兩個(gè)正整數(shù) ? ?

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

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

    目錄 1.最大公約數(shù)求法 1.1輾轉(zhuǎn)相除法 1.2相減法 2.最小公倍數(shù)求法 3.代碼實(shí)現(xiàn) 4.結(jié)果展示 1.1輾轉(zhuǎn)相除法 設(shè)有兩整數(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)

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

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

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

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

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包