0

我需要帮助来检查一些代码:

def mcd(n1,n2):
  mxcd = 0
  for i in range(1,n1):  
    f = n1 % i  
    for j in range(1,n2):
      g = n2 % j 
      if (f == 0 and g == 0 and f == g): 
        mxcd = f  
      else: 
        mxcd = "No hay comun divisor"
  return mxcd 

我有问题,因为它似乎从不进入第一个if,它总是进入else,我尝试更改缩进顺序,if从第二个中取出,for但它不起作用。如果有人可以提供帮助,那就太好了。

4

2 回答 2

0

您可以从打印出状态开始,f然后看看为什么您在声明g中没有发生任何事情。if

def mcd(n1,n2):
  mxcd = 0
  for i in range(1,n1):
    f = n1 % i
    print('i is {}, f is {}'.format(i, f))
    for j in range(1,n2):
      g = n2 % j
      print('\n  j is {}, g is {}'.format(j, g))
      if (f == 0 and g == 0 and f == g): 
        mxcd = f  
      else: 
        mxcd = "No hay comun divisor"
  return mxcd 

运行类似的东西mcd(2,4)可以让你知道很多:

i is 1, f is 0
  j is 1, g is 0  
  j is 2, g is 0    
  j is 3, g is 1
'No hay comun divisor'

确实打开了该if语句,您可以使用类似的技巧看到它:

def mcd(n1,n2):
  mxcd = 0
  for i in range(1,n1):  
    f = n1 % i  
    for j in range(1,n2):
      g = n2 % j 
      if (f == 0 and g == 0 and f == g): 
        print('hello')
        mxcd = f  
      else: 
        mxcd = "No hay comun divisor"
  return mxcd 

> mcd(4,8)

hello
hello
hello
hello
hello
hello
'No hay comun divisor'

从那里开始,您需要纠正一些问题才能获得正确的答案,但我会将这个练习留给您:)

于 2019-12-27T03:19:33.333 回答
0

您的if语句逻辑已关闭。

你要:

if (f==0 and g==0 and i==j):
    mxcd = i

你明白这是为什么吗?

此功能还有其他一些问题,但这就是它if不起作用的原因。

于 2019-12-27T03:22:47.673 回答