1. Bài tập tính tổng S(n) = 1 + 1/2 + 1/3 +…+ 1/n

Bài tập cơ bản này ta có thể có nhiều hướng giải quyết khác nhau, như sử dụng vòng lặp for , sử dụng vòng lặp while, …

Đầu vào sẽ là một biến nguyên n và yêu cầu của bài toán là tính tổng các phần tử từ 1 đến 1/n.

2. Lời giải

Để giải được bài tập tính S(n) = 1 + 1/2 + 1/3 +…+ 1/n  bạn phải có kiến thức về toán học cơ bản, có kiến thức về lập trình C cơ bản và cách sử dụng vòng lặp.

Các bước thực hiện bài toán như sau:

Bước 1: Phân tính bài toán S(n) = 1 + 1/2 + 1/3 +…+ 1/n ta thấy nó có dạng s(n) = 1/i + 1/(i+1) + 1/(i+2) + … + 1/(i+n) trong đó i bắt đầu từ 1.

Bước 2: Tạo một biến float sum = 0 để thể hiện giá trị tổng.

Bước 3: Ta sẽ sử dụng vòng for với một biến int i = 1 , điều kiện dừng khi nó bằng n và mỗi lần i tăng lên 1.

Bước 4: Trong vòng lặp ta cho biến sum mỗi lần lặp sẽ tăng lên 1/i.

Chương trình giải bài tập S(n) = 1 + 1/2 + 1/3 +…+ 1/n như sau :

#include <stdio.h>
int main(){
    // khai bao so nguyen n
    int n; 
    // khai bao sum
    float sum = 0; 
    // nhap du lieu gan vao bien n 
    printf("nhap n = ");
    scanf("%d", &n);
    //vong lap for bat dau tu i = 1 và ket thuc khi i <= n, moi lan lap i tang len 1
    for(int i = 1; i <= n; i++){
        // moi lan thuc hien vong lap bien sum se tan lên 1/i 
        sum += (float)1/i;//ép kieu float cho phép tinh 1/i vi la so nguyen chia so nguyen
    }
    // in ket qua ra man hinh    
    printf("S(%d) = %f", n,sum);
}

Ví dụ tôi nhập n = 20

Kết quả:

nhap n = 20
S(20) = 3.597740

3. Tổng kết

Để thực hiện giải bài tập tính S(n) = 1 + 1/2 + 1/3 +…+ 1/n bạn đọc cần phải có kiến thức cơ bản về ngôn ngữ lập trình C, bạn cần nắm vững cách nhập xuất căn bản và các cách sử dụng vòng lặp trong C, cách ép kiểu trong C và các phép toán học cơ bản.

Bài tập trên có thể giải bằng các khác là sử dụng vòng lặp while.

Chương trình như sau:

#include <stdio.h>
int main(){
    // khai bao so nguyen n
    int n; 
    // khai bao sum
    float sum = 0; 
    // nhap du lieu gan vao bien n 
    printf("nhap n = ");
    scanf("%d", &n);
    int i = 1;//bat dau tu i = 1
    while(i <= n){//dieu kien ket thuc vong lap i <= n
        //moi lan lap sum tang len 1/i
        sum += (float)1/i;//ep kieu float cho 1/i vi là so nguen chia so nguyen  
        i++;//moi lan lap i tang len 1
    }
    // in ket qua ra man hinh    
    printf("S(%d) = %f", n,sum);
}

Ví dụ tôi nhập n = 4

Kết quả:

nhap n = 4
S(4) = 2.083333