Thuật toán:
var n:integer;
function f(i:integer):integer;
begin
if i <= 2 then f := 1
else f := f(i-1) + f(i-2);
end;
begin
n:=100;
writeln(f(n));
end.
Giải thích: ở đây mình dùng tính dừng chương trình của thuật toán đệ quy nếu dãy fibo mà là 0,1,2 thì chắc chắn in ra sẽ là 1 nên ta sẽ không xét. Còn các trường hợp còn lại ta sử dụng thuật toán tính dạy fibo như bình thường là số cần tìm sẽ bằng tổng của 2 số sau.
@danhle
Cách 1: Dùng mảng
program fibonacci1;
uses crt;
var i,n:integer;
//ở đây có thể thay "integer" = "longint" hoặc "int64" thì sẽ được số lớn hơn.
f:array[0..1000] of integer;
begin
clrscr;
writeln('nhap vao n='); readln(n);
f[0]:=0; f[1]:=1;
for i:=2 to n do f[i]:=f[i-1]+f[i-2];
writeln(f[n]); readln;
end.
Cách 2: Câu lệnh "While"
program fibonacci2;
uses crt;
var i,n,f,f0,f1:integer;
//ở đây có thể thay "integer" = "longint" hoặc "int64" thì sẽ được số lớn hơn.
begin
clrscr;
writeln('nhap vao n='); readln(n);
f0:=0; f1:=1; i:=2;
while i<=n do
begin
f:=f0+f1;
f0:=f1;
f1:=f;
i:=i+1;
end;
write(f); readln;
end.
STUDY GOOD BRO ;-;
Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.
Nguồn : Wikipedia - Bách khoa toàn thưLớp 9 - Là năm cuối ở cấp trung học cơ sở, sắp phải bước vào một kì thi căng thẳng và sắp chia tay bạn bè, thầy cô và cả kì vọng của phụ huynh ngày càng lớn mang tên "Lên cấp 3". Thật là áp lực nhưng các em hãy cứ tự tin vào bản thân là sẻ vượt qua nhé!
Nguồn : ADMIN :))Copyright © 2021 HOCTAP247