Python使用窮舉法求兩個(gè)數(shù)的最大公約數(shù)問題
使用窮舉法求兩個(gè)數(shù)的最大公約數(shù)

for m in range (0,2):
a = int(input("請(qǐng)輸入一個(gè)數(shù):"))
b = int(input("請(qǐng)輸入另外一個(gè)數(shù):"))
#判斷num1與num2的大小
if a > b:
#獲取最小值
min = b
else:
#獲取最小值
min = a
for i in range(min+1,0,-1): #倒序
#滿足公因數(shù)的條件:
if (a % i == 0) and (b % i == 0):
c = i
break
print('這兩個(gè)數(shù)的最大公約數(shù)是:%d '%c)

窮舉法求N個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)
基本要求
求N個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)。用C或C++或java或python語言實(shí)現(xiàn)程序解決問題。
提高要求
思考一個(gè)“求公約數(shù)”和“求公倍數(shù)”之類問題的“逆問題”,這個(gè)問題是這樣的:已知正整數(shù)a0,a1,b0,b1,設(shè)某未知正整數(shù)x滿足:
- 1、x和a0的最大公約數(shù)是a1;
- 2、x和b0的最小公倍數(shù)是b1。
Hankson的“逆問題”就是求出滿足條件的正整數(shù)x。但稍加思索之后,他發(fā)現(xiàn)這樣的x并不唯一,甚至可能不存在。因此他轉(zhuǎn)而開始考慮如何求解滿足條件的x的個(gè)數(shù)。
輸入格式
- 輸入第一行為一個(gè)正整數(shù)n,表示有n組輸入數(shù)據(jù)。接下來的n行每行一組輸入數(shù)據(jù),為四個(gè)正整數(shù)a0,a1,b0,b1,每?jī)蓚€(gè)整數(shù)之間用一個(gè)空格隔開。輸入數(shù)據(jù)保證a0能被a1整除,b1能被b0整除。
輸出格式
- 輸出共n行。每組輸入數(shù)據(jù)的輸出結(jié)果占一行,為一個(gè)整數(shù)。
- 對(duì)于每組數(shù)據(jù):若不存在這樣的x,請(qǐng)輸出0;
- 若存在這樣的x,請(qǐng)輸出滿足條件的x的個(gè)數(shù);
樣例輸入
2
41 1 96 288
95 1 37 1776
算法設(shè)計(jì)思路
本程序先用窮舉法計(jì)算兩個(gè)數(shù)的最大公約數(shù)或最小公倍數(shù)。從兩個(gè)數(shù)中較小數(shù)開始由大到小列舉,直到找到公約數(shù)立即中斷列舉,得到的公約數(shù)便是最大公約數(shù) 。
①定義1:對(duì)兩個(gè)正整數(shù)a,b如果能在區(qū)間[a,0]或[b,0]內(nèi)能找到一個(gè)整數(shù)temp能同時(shí)被a和b所整除,則temp即為最大公約數(shù)。
②定義2:對(duì)兩個(gè)正整數(shù)a,b,如果若干個(gè)a之和或b之和能被b所整除或能被a所整除,則該和數(shù)即為所求的最小公倍數(shù)。
#include<stdio.h>
#define N 1000 ?/*自定義數(shù)組長(zhǎng)度*/
int input(int t[])
{
?? ?int i,n;
?? ?int k=1;
?? ?printf("Please input the count of numbers(n>=2):"); /*輸入計(jì)算值的個(gè)數(shù)*/
?? ?scanf("%d",&n);
?? ?while(k)
?? ?{
?? ??? ?printf("Please input numbers:\n"); ?/*輸入所算值*/
?? ??? ?for(i=0;i<n;i++)
?? ??? ?{
?? ??? ??? ?scanf("%d",&t[i]);
?? ??? ?}
?? ??? ?k=exper(t,n);
?? ?}
?? ?return n;
}
int exper(int t[],int n) ? /*驗(yàn)證函數(shù)*/
{
?? ?int i;
?? ?for(i=0;i<n;i++)
?? ?{
?? ??? ?if(!t[i])
?? ??? ?{
?? ??? ??? ?printf("error(輸入為0)\n");
?? ??? ??? ?return 1;
?? ??? ?}
?? ?}
? ?return 0;
}
int divisor (int a,int b) /*自定義函數(shù)求兩數(shù)的最大公約數(shù)*/
{
? ? int ?temp; ? ? ? ? ?/*定義義整型變量*/
? ? temp=(a>b)?b:a; ? ?/*采種條件運(yùn)算表達(dá)式求出兩個(gè)數(shù)中的最小值*/
? ? while(temp>0)
? ? {
? ? ? ?if (a%temp==0&&b%temp==0) /*只要找到一個(gè)數(shù)能同時(shí)被a,b所整除,則中止循環(huán)*/
? ? ? ? ? break;
? ? ? ?temp--; ? ? ?/*如不滿足if條件則變量自減,直到能被a,b所整除*/
? ? }
? return (temp); /*返回滿足條件的數(shù)到主調(diào)函數(shù)處*/
}
int Gcd(int t[],int n)
{
?? ?int i;
?? ?int c=t[0];
?? ?for(i=1;i<n;i++)
?? ?{
?? ??? ?c=divisor(c,t[i]); ?/*求N個(gè)數(shù)的最大公約數(shù)*/
?? ?}
?? ?return c;
}
int multiple (int a,int b)
{
? int p,q,temp;
? p=(a>b)?a:b; ? /*求兩個(gè)數(shù)中的最大值*/
? q=(a>b)?b:a; ?/*求兩個(gè)數(shù)中的最小值*/
? temp=p; ? ? ?/*最大值賦給p為變量自增作準(zhǔn)備*/
? while(1) ??
? {
? ? if(p%q==0)
? ? ? break; ?/*只要找到變量的和數(shù)能被a或b所整除,則中止循環(huán)*/
? ? p+=temp; ? /*如果條件不滿足則變量自身相加*/
? }
? return ?(p);
}
int Mul(int t[],int n)
{
?? ?int i;
?? ?int s=t[0];
?? ?for(i=0;i<n;i++)
?? ?{
?? ??? ?s=multiple(s,t[i]); ?/*求N個(gè)數(shù)的最小公倍數(shù)*/
?? ?}
?? ?return s;
}
int main()
{
?int t[N];
?int n;
?int flag=1;
?while(flag)
?{
? ? n=input(t);
? ? printf("The higest common divisor is %d\n",Gcd(t,n)); ?/*輸出最大公約數(shù)*/
? ? printf("The lowest common multiple is %d\n",Mul(t,n));/*輸出最小公倍數(shù)*/
? ? printf("retreat:press 0\ncontiune:press 1");
? ? scanf("%d",&flag);
?}
?return 0;
}測(cè)試截屏
輸入數(shù)據(jù)正確時(shí):

輸入數(shù)據(jù)有0時(shí)會(huì)提示錯(cuò)誤,計(jì)算完成后可以退出和繼續(xù):

總結(jié)
求N個(gè)數(shù)的最大公約數(shù)和最小公倍數(shù)的可以聯(lián)系上機(jī)作業(yè):用四種方法求兩個(gè)數(shù)最大公約數(shù)和最小公倍數(shù),像這種思考方式可以用于以后的解決問題中。
在完成基本要求中,程序完成比較順利。提高要求仔細(xì)讀了幾遍,明白了題意,尋找滿足x的個(gè)數(shù),這就要用到循環(huán)和計(jì)數(shù)器一個(gè)個(gè)去找,但此要求最終沒能完成,在對(duì)x的求解過程仍有問題。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Numpy中創(chuàng)建數(shù)組的9種方式小結(jié)
本文主要介紹了Numpy中創(chuàng)建數(shù)組的9種方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Python中所有子圖標(biāo)簽Legend顯示問題記錄
在Python中,利用matplotlib創(chuàng)建的子圖可以很容易地添加圖例,無論是為每個(gè)子圖單獨(dú)添加,還是統(tǒng)一在一起,本文詳細(xì)介紹了如何在多個(gè)子圖中顯示圖例,包括全局圖例的顯示、圖例樣式的調(diào)整和圖例位置的調(diào)整等,需要的朋友可以參考下2024-12-12
Python讀取txt文件數(shù)據(jù)的方法(用于接口自動(dòng)化參數(shù)化數(shù)據(jù))
這篇文章主要介紹了Python讀取txt文件數(shù)據(jù)的方法(用于接口自動(dòng)化參數(shù)化數(shù)據(jù)),需要的朋友可以參考下2018-06-06
Python urllib request模塊發(fā)送請(qǐng)求實(shí)現(xiàn)過程解析
這篇文章主要介紹了Python urllib request模塊發(fā)送請(qǐng)求實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12
django實(shí)現(xiàn)web接口 python3模擬Post請(qǐng)求方式
今天小編就為大家分享一篇django實(shí)現(xiàn)web接口 python3模擬Post請(qǐng)求方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11
簡(jiǎn)單談?wù)刾ython中的Queue與多進(jìn)程
本文給大家簡(jiǎn)單總結(jié)了下再Python中的隊(duì)列對(duì)象(queue)以及多進(jìn)程(multiprocessing),非常的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下2016-08-08

