VietTuts

Tự Học Lập Trình Online

  • Home
  • Java
  • Servlet
  • JSP
  • Struts2
  • Hibernate
  • Spring
  • MyBatis
  • Java WS
  • C
  • C++
  • Python
  • PHP
  • Eclipse
  • VBA
  • Web
    • JavaScript
    • JQUERY
    • JSON
    • AJAX
    • CSS
    • HTML
    • Node.js
    • Angular 7
  • SQL
    • MySQL
    • SQL Server
  • Misc
    • Phần mềm tiện ích
    • Cấu trúc dữ liệu và giải thuật
    • Học lập trình C#
    • Selenium Test
C Cơ Bản Chuỗi (String) Trong C Xử Lý File Trong C

Bài Tập C

Danh sách bài tập C

Bài Tập C Kinh Điển

Dãy số Fibonacci trong C Check số nguyên tố trong C Tính giai thừa trong C Chuyển đổi hệ cơ số trong C

Bài Tập C Cơ Bản

Giải phương trình bậc 2 Tìm UCLN và BCNN Liệt kê tất cả số nguyên tố nhỏ hơn n Liệt kê n số nguyên tố đầu tiên Liệt kê tất cả số nguyên tố có 5 chữ số Phân tích số nguyên Tính tổng của các chữ số của một số nguyên Tìm số thuận nghịch Liệt kê số Fibonacci nhỏ hơn n là nguyên tố

Bài Tập Vòng Lặp C

Bài tập vòng lặp trong C Vẽ tam giác đều trong C Vẽ tam giác vuông cân trong C Vẽ tam giác Floyd trong C Vẽ tam giác Pascal trong C

Bài Tập Mảng Trong C

In mảng trong C Nhập mảng từ bàn phím trong C Tính tổng giá trị của một mảng trong C Tính giá trị trung bình của một mảng trong C Sao chép mảng trong C Chia một mảng thành hai mảng trong C Trộn hai mảng thành một mảng trong C

Bài Tập Mảng 2 Chiều Trong C

Nhập ma trận từ bàn phím trong C Trừ hai ma trận trong C Cộng hai ma trận trong C Tính tổng tất cả các phần tử của ma trận trong C

Bài tập chuỗi trong C

Nhập chuỗi từ bàn phím trong C Bài tập C - In chuỗi trong C Tìm độ dài chuỗi trong C Tìm số lần xuất hiện của một ký tự trong một chuỗi trong C Sắp xếp các ký tự của chuỗi theo thứ tự bảng chữ cái trong C Sao chép chuỗi trong C Đảo ngược chuỗi trong C Tìm kiếm chuỗi trong C So sánh hai chuỗi trong C Nối chuỗi trong C Đảo ngược các ký tự của từng từ của một chuỗi trong C Đảo ngược thứ tự từ của một chuỗi trong C Sắp xếp các chuỗi theo thứ tự chữ cái trong C Chuyển đổi chuỗi thành số nguyên trong C Biến đổi chuỗi thành chữ hoa trong C Biến đổi chuỗi thành chữ thường trong C

Bài tập về các thuật toán sắp xếp trong C

Sắp xếp nổi bọt (Bubble Sort) trong C Sắp xếp chọn (Selection Sort) trong C Sắp xếp chèn (Insertion Sort) trong C Sắp xếp nhanh (Quick Sort) trong C Sắp xếp trộn (Merge Sort) trong C Sắp xếp Shell Sort trong C

Bài Tập C Nâng Cao

Bài tập quản lý sinh viên trong C/C++

Tính giai thừa trong C


Check số nguyên tố trong C
Chuyển đổi hệ cơ số trong C

Nội dung chính

  • Đề bài
  • Lời giải
  • Tính giai thừa không sử dụng đệ quy
  • Tính giai thừa có sử dụng đệ quy

Đề bài

Viết chương trình C tính giai thừa của một số nguyên dương.

Định nghĩa giai thừa: giai thừa của 1 số là tích các số liên tiếp từ 1 đến số đó. Trường hợp đặc biệt, giai thừa của 0 và 1 là 1.

Ví dụ: giai thừa của 5 là 1*2*3*4*5 = 120



Lời giải

Có 2 cách để viết chương trình tính giai thừa trong C:

  • Tính giai thừa không sử dụng đệ quy.
  • Tính giai thừ có sử dụng đệ quy.

Tính giai thừa không sử dụng đệ quy

Ví dụ chương trình tính giai thừa trong C không sử dụng phương pháp đệ quy:


/**
 * Tinh giai thua KHONG dung phuong phap de quy
 *  
 * @author viettuts.vn
 */

#include<stdio.h>

/**
 * tinh giai thua
 * 
 * @author viettuts.vn
 * @param n: so nguyen duong
 * @return giai thua cua so n
 */
long tinhGiaithua(int n) {
 int i;
    long giai_thua = 1;
    if (n == 0 || n == 1) {
        return giai_thua;
    } else {
        for (i = 2; i <= n; i++) {
            giai_thua *= i;
        }
        return giai_thua;
    }
}

/**
 * Ham main
 */
int main() {
    int a = 5;
    int b = 0;
    int c = 10;
    printf("Giai thua cua %d  la: %d \n",  a, tinhGiaithua(a));
    printf("Giai thua cua %d  la: %d \n",  b, tinhGiaithua(b));
    printf("Giai thua cua %d  la: %d",  c, tinhGiaithua(c));
}

Kết quả:

Giai thua cua 5  la: 120
Giai thua cua 0  la: 1
Giai thua cua 10  la: 3628800


Tính giai thừa có sử dụng đệ quy

Ví dụ chương trình tính giai thừa trong C có sử dụng phương pháp đệ quy:


/**
 * Tinh giai thua su dung phuong phap de quy
 *  
 * @author viettuts.vn
 */

#include<stdio.h>

/**
 * tinh giai thua
 * 
 * @author viettuts.vn
 * @param n: so nguyen duong
 * @return giai thua cua so n
 */
long tinhGiaithua(int n) {
    if (n > 0) {
        return n * tinhGiaithua(n - 1);
    } else {
        return 1;
    }
}

/**
 * Ham main
 */
int main() {
    int a = 5;
    int b = 0;
    int c = 10;
    printf("Giai thua cua %d  la: %d \n",  a, tinhGiaithua(a));
    printf("Giai thua cua %d  la: %d \n",  b, tinhGiaithua(b));
    printf("Giai thua cua %d  la: %d",  c, tinhGiaithua(c));
}

Kết quả:

Giai thua cua 5  la: 120
Giai thua cua 0  la: 1
Giai thua cua 10  la: 3628800

Check số nguyên tố trong C
Chuyển đổi hệ cơ số trong C

Recent Updates

Dãy số Fibonacci trong C#Bài tập C# có lời giảiToán tử dấu 2 chấm (::) trong Java 8Lambda Expression - Biểu thức Lambda trong java 8HttpClient trong Angular 7Service trong Angular7Directive trong Angular 7Component trong Angular 7Hướng dẫn lập trình Angular 7 với trình soạn thảo Visual Studio CodeCài đặt Angular 7Các lệnh Angular CLITổng hợp các thẻ mới trong HTML5

VietTuts on facebook

Học Lập Trình Online Miễn Phí - VietTuts.Vn

Danh sách bài học

Học java
Học servlet
Học jsp
Học Hibernate
Học Struts2
Học Spring
Học SQL

Câu hỏi phỏng vấn

201 câu hỏi phỏng vấn java
25 câu hỏi phỏng vấn servlet
75 câu hỏi phỏng vấn jsp
52 câu hỏi phỏng vấn Hibernate
70 câu hỏi phỏng vấn Spring
57 câu hỏi phỏng vấn SQL

About VietTuts.Vn

Hệ thống bài học trên VietTuts.Vn bao gồm các bài lý thuyết và thực hành về các công nghệ java và công nghệ web. Các bài lý thuyết trên hệ thống VietTuts.Vn được tham khảo và tổng hợp từ các trang http://javatpoint.com, http://www.tutorialspoint.com, http://docs.oracle.com/en …

Scroll back to top

Copyright © 2016 VietTuts.Vn all rights reserved. | VietTuts.Vn team | Liên hệ | Chính sách - riêng tư | sitemap.html | sitemap_index.xml