06/04/2021, 14:47

[Bài tập C] Tìm số giai thừa bằng đệ quy - Bài tập C có lời giải

Trong bài viết này chúng ta sẽ tìm hiểu cách tính giai thừa của một số bằng cách sử dụng thuật toán đệ quy và viết trong ngôn ngữ lập trình C. Công thức tính giai thừa rất đơn giản, n! = 1x2x3x ... x n. Ví dụ: 4! = 1 x 2 x 3 x 4 = 24. Chương trình C này ...

Trong bài viết này chúng ta sẽ tìm hiểu cách tính giai thừa của một số bằng cách sử dụng thuật toán đệ quy và viết trong ngôn ngữ lập trình C.

Công thức tính giai thừa rất đơn giản, n! = 1x2x3x ... x n.

Ví dụ: 4! = 1 x 2 x 3 x 4 = 24.

Chương trình C này cho phép người dùng nhập một số nguyên bất kì, sau đó tính giai thừa và in ra kết quả lên màn hình console. Mình se tạo ra một hàm đệ quy để giải quyết bài toán này. Ở đây ta có một hàm find_factorial tự gọi nó theo cách đệ quy để tìm ra giai thừa của số đầu vào.

Chương trình tìm giai thừa bằng C

/* Program Name: Tinh giai thua bang C
   Published on: Zaidap.com.net
 */
#include<stdio.h>
int find_factorial(int);
int main()
{
   int num, fact;
   printf("
Nhap so can tinh giai thua:");
   scanf("%d",&num);
 
   //Gọi đến hàm tính giai thừa
   fact =find_factorial(num);
 
   //Hiển thị kết quả lên màn hình
   printf("
Giai thua cua %d la: %d",num, fact);
   return 0;
}
int find_factorial(int n)
{
   // Giai thừa của 0 bằng 1, đây là trường hợp đặc biệt. 
   // Và cũng là điều kiện dừng đệ quy
   if(n==0)
      return(1);
 
   //Tính giai thừa cho số tiếp theo phía sau
   return(n*find_factorial(n-1));
}

Giả sử bạn nhập số cần kiểm tra là 4 thì kết quả sẽ như sau:

Nhap so can kiem tra: 4
Giai thua cua 4 la: 24

Trên là bài tập tìm số giai thừa bằng ngôn ngữ lập trình C. Chúc bạn thực hiện thành công!

Trần Trung Dũng

15 chủ đề

2610 bài viết

0