
Danh sách bài học
Viết hàm đệ quy tính só fibonacci thứ n
Bài toán cần xử lý
Viết hàm tính số Fibonacci thứ n (Dùng đệ quy). Với tham số là số tự nhiên n.
Kiến thức cần có
- Hàm input() và hàm print()
- Cấu trúc lặp trong Python
- Cấu trúc rẽ nhánh trong Python
- Biến và kiểu dữ liệu
- Hàm trong Python
- Xử lý ngoại lệ (Exception Handling)
Định dạng đầu vào
Gồm một dòng duy nhất chứa số tự nhiên n
Định dạng đầu ra
- Gồm một dòng duy nhất hiển thị số Fibonacci thứ n.
Lưu ý: Nếu n nhỏ hơn hoặc bằng 0 thì xuất thông báo: Vui long nhap so nguyen duong!
Nếu input nằm ngoài định dạng đầu vào thì xuất thông báo: Dinh dang dau vao khong hop le!
Ví dụ
- Input 1:
1
- Output 1:
1
- Input 2:
38
- Output 2:
39088169
- Input 3:
-1457
- Output 3:
Vui long nhap so tu nhien!
- Input 4:
Kteam
- Output 4:
Dinh dang dau vao khong hop le!
Gợi ý
- Định nghĩa hàm giai_thua với các tham số là số tự nhiên n
- Nếu n == 1 hoặc 2 thì trả về 1
- Nếu không thì gọi đệ quy trả về fibonacci(n-1) + fibonacci(n-2)
- Sử dụng cấu trúc Xử lý ngoại lệ để xử lý các trường hợp gây ra lỗi
- Đặt toàn bộ chương trình trong khối try.
- Dùng hàm input() để nhập giá trị n từ bàn phím.
- Chuyển giá trị n mới nhận được sang kiểu số nguyên, vì các giá trị nhận được từ hàm input() mặc định sẽ ở kiểu chuỗi.
- Sử dụng cấu trúc rẽ nhánh để xử lý trường hợp nhỏ hơn hoặc bằng 0. Hiển thị thông báo nếu có.
- Gọi hàm fibonacci và truyền vào tham số n.
- Hiển thị ra màn hình kết quả theo định dạng đầu ra yêu cầu
- Lỗi sẽ phát sinh ở lệnh ép kiểu nếu định dạng đầu vào không hợp lệ. Dùng lệnh except để bắt lỗi:
- Dùng hàm print() hiển thị thông báo lỗi ra màn hình
Code mẫu
def fibonacci(n):
if n == 1 or n == 2:
return 1
return fibonacci(n-1) + fibonacci(n-2)
#Khoi lenh co the phat sinh loi
try:
#Nhap gia tri tu ban phim
#Ep kieu du lieu sang so nguyen
n = int(input())
#Su dung cau truc re nhanh xu ly truong hop n <= 0
if n <= 0:
print("Vui long nhap so nguyen duong!")
else:
print(fibonacci(n))
#Khoi lenh duoc thuc thi khi loi xay ra
except:
print("Dinh dang dau vao khong hop le!")
Kết luận
Trong bài này, Kteam đã hướng dẫn bạn cách viết hàm tính số Fibonacci thứ n (Dùng đệ quy). Với tham số là số tự nhiên n.Thêm bài giải của bạn vào phần bình luận để được Kteam review code và fix lỗi (nếu có) trong livestream của khóa học này.
Ở bài tiếp theo, chúng ta sẽ cũng nhau học cách VIẾT HÀM LIỆT KÊ CÁC SỐ NGUYÊN TỐ TRONG ĐOẠN TỪ A ĐẾN B (A,B LÀ SỐ TỰ NHIÊN, A<=B)
Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của bạn để phát triển bài viết tốt hơn. Đừng quên " Luyện tập - Thử Thách - Không ngại khó!"
Tải xuống
Tài liệu
Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Viết hàm đệ quy tính só fibonacci thứ n dưới dạng file PDF trong link bên dưới.
Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com
Đừng quên like và share để ủng hộ Kteam và tác giả nhé!

Thảo luận
Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.
Nội dung bài viết
Khóa học
Serial dành cho những bạn cần luyện tập phương pháp, tu duy lập trình. Làm quen với các bài toán trong lập trình, ngẫu nhiên từ cơ bản đến nâng cao. Nội dung Serial này được phân tách chi tiết nhất có thể, nhằm giúp các bạn dễ hiểu và thực hành được ngay.
Bạn nên tự làm lại từng bài tập trên video để có kết quả tốt nhất. Cùng Kteam "Luyện tập - Thử thách - không ngại khó"
def fibonacci(n):
if n == 0:
return 0
elif n == 1:
return 1
else:
return fibonacci(n-1) + fibonacci(n-2)
try:
n = int(input("input number: "))
if n < 0:
print("Please input with n > 0")
else:
print(f"Fibonacci{n} is {fibonacci(n)}")
except ValueError:
print("input value error")
def fibo(n):
if n <= 1:
return n
else:
return fibo(n-1) + fibo(n-2)
while True:
try:
n = int(input("Nhập 1 số: "))
if n < 0:
print("Vui lòng nhập số nguyên dương!")
else:
print(fibo(n))
break
except:
print("Định dạng đầu vào không hợp lệ!")
n = int(input('input number: '))
def fibonaci (n):
count=1
i=1
h=0
while count < n :
i = i + h
h = i - h
count +=1
return i
if n <= 0 :
print('vui long nhap so tu nhien')
else:
print(fibonaci(n))
def sothu2(n):
sothu1=1
sothu2=1
for i in range(1,n-1):
sothu3=sothu1+sothu2
sothu1,sothu2=sothu2,sothu3
return sothu2
#Khung
try:
n=int(input("Nhap số tự nhiên n: "))
if n<0:
print("Vui lòng nhập số nguyên dương")
elif n==1 or n==2:
print("1")
else:
print(sothu2(n))
except:
print("Dinh dang dau vao khong hop le!")
Code mẫu chỉ để tham khảo về cách dùng hàm thôi chứ chạy chậm quá. Cách nguyên thủy này nhanh hơn
def Fb(n:int):
Fn_1=1
Fn_2=1
Fn=0
if n==1:
Fn=1
elif n==2:
Fn=1
else:
for i in range(3,n+1):
Fn=Fn_1+Fn_2
Fn_2=Fn_1
Fn_1=Fn
return Fn
print(Fb(38))