Viết Chương Trình In Ra Các Số Hoàn Hảo C++ - Hỏi Đáp

1. Số hoàn hảo là gì?

Số hoàn hảo (perfect number) hay còn gọi là số hoàn thiện là số: nguyên dương mà tổng các ước nguyên dương chính thức của nó bằng chính nó.Ước chính thức là các ước mà số đó chia hết trừ nó và bao gồm cả số 1.

Ví dụ số hoàn hảo:

  • 6 là số hoàn hảo, các ước chính thức của 6: 1, 2, 3Ta có : 6 = 1 + 2 + 3
  • 28 là số hoàn hảo: 1 + 2 + 4 + 7 + 14 = 28
  • 10 không phải số hoàn hảo: 1+ 2 + 5 = 8 (khác 10)

Ta sẽ giải quyết bài toán áp dụng tư tưởng theo đúng định nghĩa. Để kiếm tra số nguyên dương n có phải là số hoàn hảo hay không, thuật toán đưa ra ở đây chính là duyệt và tìm tất cả các ước của n sau đó cộng lại.

Áp dụng vào lập trình ta sẽ giải quyết nó như sau:

  • Khai báo một biến tam = 0; biến này sẽ dùng để tính tổng các ước
  • Sử dụng vòng lặp i từ 0 đến nhỏ hơn n. Nếu i là ước của n (tức là n % i ==0) thì ta cộng tam với i : tam = tam + i;
  • So sánh tam với ntam với 0. Nếu tam == ntam !=0 thì tức là số đó là số hoàn hảo, ngược lại thì không.

Sẽ có bạn thắc mắc tại sao ta không xét trường hợp n < 1. Thật ra với cách làm nêu trên, ta cho vòng lặp for từ 0 đến nhỏ hơn n. Vì thế, nếu n nhỏ hơn 1 thì ta luôn thu được tam =0. mà tam =0 thì ta đã loại rồi.

2. Kiểm tra số hoàn hảo C/C++

Mình sẽ triển khai hàm kiểm tra một số nguyên dương n có phải là số hoàn hảo hay không dựa theo đúng ý tưởng nêu ở phần 1 nhé!

Code C/C++:

// Ham kiem tra so hoan hao bool kt_hoanhao(int n){ int tam =0; // Khai báo biến tạm lưu tổng các ước for(int i=1; i i là ước chính thức của n tam = tam + i; // cộng vào tổng các ước } if(tam !=0 && tam == n) // Nếu tổng các ước khác 0 và bằng n trả về true return true; else // Nếu tam khác n hoặc tam ==0 thì trả về false return false; }

Khi có hàm kiểm tra số hoàn thiện, ta có thể áp dụng vào các bài tập tương ứng. Ví dụ như (in các số hoàn hảo trong mảng, các số ht nhỏ hơn n . . .)

Dưới đây mình triển khai chương trình in ra tất cả các số hoàn thiện trong mảng trong C++ nhé!

Code C++:

#include using namespace std; // Ham kiem tra so hoan hao bool kt_hoanhao(int n){ int tam =0; for(int i=1; i

Từ khóa » Số Hoàn Hảo C++ Là Gì