簡體   English   中英

遞歸函數使a ^ b

[英]Recursive function to make a^b

我的遞歸函數似乎不起作用-應該采用參數ab並返回a^b

這里是:

def power(a, b):
       If b == 0:
               return
       return a * power(a,  b-1)
power(2,  3)

基本案例的返回語句為null。 您應該返回1(因為a^0 = 1表示a != 0 )。

if b == 0:
    return 1

但是,您可能想單獨處理a = 0的情況,因為0^0在數學上是未定義的:

if a == 0:
    if b > 0:
        return 0
    else
        # raise an exception here?
def power(a, b):
   if b == 0:
      return 1;
   return a * power(a,  b - 1);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM