Viết chương trình in ra các số hoàn hảo C++
Thuật toán kiểm tra số hoàn hảo trong C/C++. Ứng dụng vào bài toán tìm, liệt kê số hoàn hảo trong mảng các số nguyên dương n phần tử, số hoàn thiện nhỏ hơn n. Show Kiểm tra số hoàn hảo trong lập trình C/C++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ó. Ví dụ số hoàn hảo:
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:
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; iKhi 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++: Perfect number là một dạng bài tập khá hay, nó giúp bạn hiểu hơn về tư duy lập trình, cách kết hợp vòng lặp, câu điều kiện . . . Từ đó giúp bạn cải thiện về kĩ năng của bản thân. Luyện tập từ những thứ nhỏ nhất, bạn sẽ thấy được sự phát triển của mình. Bài viết của mình đến đây là hết, nếu bạn có lời khuyên gì cho mình hay bất kỳ thắc mắc nào, đừng ngại để lại comment xuống phía dưới bài viết nhé! Xem thêm các bài viết về thuật toán, lập trình C/C++ khác của mình tại đây.
|