c語言求最大公約數,C語言求最大公約數函數

  • 生活
  • 2023-05-30 10:42

今天給各位分享c語言求最大公約數的知識,其中也會對C語言求最大公約數函數進行解釋,如果能碰巧解決你現在面臨的問題,別忘了關注本站,現在開始吧!

如何用C語言求兩個數的最大公約數的三種算法

1、相減法

#includelt;stdio.hgt;

intmain()

{

inta,b;

intc=0;//計數器

while(1)//循環判斷的作用

{

printf("輸入兩個數字求最大公約數:");

scanf("%d%d",a,b);

while(a!=b)

{

if(agt;b)

a=a-b;

else

b=b-a;

c++;

}

printf("最大公約數是:%d ",a);

printf("%d ",c);

}

return0;

}

運行效果:

2、輾轉相除法:

#includelt;stdio.hgt;

inta,b,temp;

intDivision(){

printf("請輸入兩個數(a,b): ");

scanf("%d,%d",a,b);

if(alt;b){

temp=a;

a=b;

b=temp;

}

while(a%b!=0){

temp=a%b;

a=b;

b=temp;

}

printf("最大公約數為:%d ",b);

return0;

}

3、窮舉法

#includelt;stdio.hgt;

intmain()

{

inta,b,c;

intd=0;//計數器

while(1)

{

printf("輸入兩個數字求最大公約數:");

scanf("%d%d",a,b);

c=(agt;b)?b:a;//三目運算符

while(a%c!=0||b%c!=0)

{

c--;

d++;

}

printf("最大公約數是:%d ",c);

printf("%d ",d);

}

return0;

}

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=ab中的小數

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

③i--,再回去執行②

c語言求最大公約數

1、新建一個C語言源程序,這里使用VisualC++6.0的軟件:

2、從鍵盤中輸入兩個正整數a和b。取兩個數a,b中的較小值存放到變量n中。從兩個數a和b中的較小數開始逐個減小1,尋找能整除a和b的整數,第一個找到的整數即整數a和b的最大公約數,最后將找到的結果輸出即可完成程序的編寫:

3、對源程序編譯運行,測試輸入4、6,得到最大公約數2說明程序是正確的,以上就是用c語言求最大公約數的過程:

關于c語言求最大公約數的內容到此結束,希望對大家有所幫助。

猜你喜歡

主站蜘蛛池模板: 在线观看成人无码中文av天堂| 无码精品一区二区三区| 少妇人妻偷人精品无码视频| 国产在线精品无码二区二区| 国内精品无码一区二区三区| 无码人妻丝袜在线视频| 成人免费无码精品国产电影| 无码日韩精品一区二区免费暖暖 | 免费A级毛片无码A∨男男| 亚洲中文字幕无码日韩| 亚洲第一极品精品无码久久| 国产成年无码v片在线| 性无码专区无码片| 国产综合无码一区二区三区| 人妻少妇精品无码专区动漫| 久久午夜夜伦鲁鲁片无码免费| 自慰系列无码专区| 麻豆亚洲AV永久无码精品久久| 久久亚洲国产成人精品无码区| 无码专区永久免费AV网站| 精品国产a∨无码一区二区三区 | V一区无码内射国产| 大胆日本无码裸体日本动漫| 国产成人麻豆亚洲综合无码精品 | 国产精品无码一区二区三级 | 日韩av无码一区二区三区| 亚洲欧洲自拍拍偷午夜色无码| 亚洲高清无码专区视频| 深夜a级毛片免费无码| 日韩乱码人妻无码中文字幕视频| 久久久精品天堂无码中文字幕| 精品无码国产自产在线观看水浒传| 日韩精品人妻系列无码专区| 亚洲AV无码一区东京热| 久久久无码一区二区三区| 18禁无遮挡无码国产免费网站| 亚洲精品中文字幕无码AV| 无码人妻精品一区二区蜜桃网站| 久久久久亚洲AV无码观看| 免费无码黄十八禁网站在线观看| 久久久国产精品无码一区二区三区 |