Bạn đã không trả lại giá trị mà bạn đã tính toán cho đến nay khi các số đồng đều. Thay vào đó bạn đã trả lại giá trị đầu vào n. Bằng cách này, bạn chỉ đơn giản là tổng giá trị N trước đó
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
2. Làm điều đó, khi bạn đã làmdef sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
3IT đã trả lạidef sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
4 đó là 11. If you doingdef sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
5, it will đơn giản là trả lại 5Vì điều kiện dừng ở trên không chính xác, bạn cần một điều kiện thích hợp. Bạn muốn thêm tất cả các số ngày cho đến khi không [và không phải
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
6], vì vậyif n==0:
return 0
chỉnh sửa. hoặc, đã được đề xuất bởi Stef, bạn chỉ có thể di chuyển trong 2 x 2 thay vì 1 lần 1 lần khi bạn tìm thấy số lần đầu tiên của mình
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
0Đã trả lời ngày 27 tháng 11 năm 2020 lúc 12. 25 27/11/2020 lúc 12. 25
Willcrackwillcrack willcrack
1. 6949 huy hiệu bạc18 Huy hiệu đồng9 huy hiệu bạc18 huy hiệu đồng
2
Tôi sẽ đề xuất một cách tiếp cận phân chia và chính dựa trên ý tưởng rằng tổng trong toàn bộ phạm vi có thể được tìm thấy bằng cách thêm tổng của nửa phân nửa đầu vào tổng của nửa phân vi thứ hai. Điều này chia nhỏ kích thước của biểu tượng con một nửa cho mỗi cuộc gọi đệ quy thay vì đã đưa nó xuống một lần. Các giải pháp được đặt tên khác nhau sẽ là Ngăn xếp đệ quy cho những người đầu tiên vào hơn 2000, trong khi phương pháp này hoạt động với số lượng lớn
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
1Như bạn có thể thấy, tôi cũng đã cung cấp một thói quen
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
7 để xác nhận câu trả lời. Điều này dựa trên quan sát rằng tổng của các giám đốc tối nay lên đếndef sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
8 bằngdef sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
9. . Do đó, cắm vàoif n==0:
return 0
3 cho_______51 và nhận thấy rằng hủy bỏ 2, chúng tôi nhận được công thức trongdef sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
7 - đó là những gì bạn thực sự nên sử dụng thay vì đệ quyĐã trả lời ngày 8 tháng 12 năm 2020 lúc 19. 08 8 tháng 12, 2020 lúc 19. 08
pjspjs pjs
17,9K4 Huy hiệu vàng25 Huy hiệu bạc 50 Huy hiệu Đồng4 huy hiệu vàng25 huy hiệu bạc50 bronze badges
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
8Điều này nên làm điều đó. Điều duy nhất còn thiếu trong mã của bạn là điều kiện khi
if n==0:
return 0
6 nên dừng lạiĐã trả lời ngày 27 tháng 11 năm 2020 lúc 11. 58 27/11/2020 lúc 11. 58
ombkombk ombk
2. 0281 Huy hiệu vàng3 Huy hiệu bạc15 Huy hiệu đồng1 huy hiệu vàng3 huy hiệu bạc15 huy hiệu đồng
You could try this thing
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
60Đã trả lời ngày 27 tháng 11 năm 2020 lúc 12. 53 27/11/2020 lúc 12. 53
Gorginegorgine Gorgine
3102 Huy hiệu bạc10 Huy hiệu đồng2 huy hiệu bạc10 huy hiệu đồng
Có một công thức đóng kín cho điều này, vì vậy không cần lặp lại. ngay cả khi bạn đã được nhân đôi của chuỗi số hình tam giác, và công thức đó là gấp đôi 𝑛/2 [𝑛/2+1]/2 là 𝑛 /2 [𝑛/2+1]. Đối với ODD, kết quả giống như đối với 𝑛-1
Vì vậy, could code is
def sum_of_even[n]:
if n==0:
return 0
if not n % 2 == 0:
return sum_of_even[n-1]
else:
return n + sum_of_even[n-1]
print[sum_of_even[10]]
61Nhưng vì câu hỏi là về đệ quy, thì hãy xác định trường hợp cơ sở khi 𝑛 nhỏ hơn 2 [có nghĩa là kết quả là 0]. Mặt khác, khi số là lẻ, giải quyết vấn đề trong 1 ít hơn [nó có cùng kết quả]. Nếu số buổi tối, giải quyết vấn đề ít hơn 2 và thêm vào kết quả đó