求兩個數互質演算法

來源:互聯網
上載者:User

用歐幾裡德演算法(輾轉相除法)求兩個數的最大公約數的步驟如下:
先用小的一個數除大的一個數,得第一個餘數;
再用第一個餘數除小的一個數,得第二個餘數;
又用第二個餘數除第一個餘數,得第三個餘數;
這樣逐次用後一個數去除前一個餘數,直到餘數是0為止。那麼,最後一個除數就是所求的最大公約數(如果最後的除數是1,那麼原來的兩個數是互質數)。 
 void f(const int m,const int n)
 {
  int d1,d2,d3=1;
  if(m<=n)                      //將小數放到d1中
  {
   d1=m;
   d2=n;
  }
  else
  {
   d1=n;
   d2=m;
  }
  while(d3!=0)
  {
   d3=d2%d1;
   d2=d1;
   d1=d3;
  }
  cout<<m<<"和"<<n<<"最大公約數是:"<<d2<<endl;

if(d2==1)cout<<m<<"和"<<n<<"互質"<<endl;
  else cout<<m<<"和"<<n<<"不互質"<<endl;

}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.