Kiểm Tra Số Chính Phương Trong C++
Có thể bạn quan tâm
Hướng dẫn cách kiểm tra số chính phương trong C++. Bạn sẽ học được cách tạo hàm kiểm tra số chính phương trong C++ cũng như cách liệt kê tất cả các số chính phương nhỏ hơn n bằng C++ sau bài học này.
Chúng ta có 2 phương pháp để kiểm tra số chính phương trong C++ như sau:
- Kiểm tra số chính phương trong C++ bằng lũy thừa
- Kiểm tra số chính phương trong C++ bằng căn bậc 2
Số chính phương trong C++
Theo wikipedia thì khái niệm số chính phương như sau:
Số chính phương hay còn gọi là số hình vuông là số tự nhiên có căn bậc hai là một số tự nhiên, hay nói cách khác, số chính phương bằng bình phương của một số tự nhiên.
Khái niệm số chính phương trong C++ cũng giống như trên. Chúng ta coi một số là số chính phương trong C++ nếu như nó bằng bình phương của một số tự nhiên. Đây là chìa khóa thứ nhất giúp chúng ta có thể tìm được số chính phương trong C++.

Nói cách khác, căn bậc 2 của một số chính phương chính là một số tự nhiên. Đây là chìa khóa thứ 2 giúp chúng ta có thể tìm được số chính phương trong C++.
Kiểm tra số chính phương trong C++ bằng lũy thừa
Cách đầu tiên để kiểm tra số chính phương trong C++ là sử dụng khái niệm số chính phương bằng bình phương của một số tự nhiên.
Điều đó có nghĩa, với một số bất kỳ, nếu chúng ta có thể tìm được một số tự nhiên mà bình phương của nó bằng với số đã cho, thì số đó chính là số chính phương.
Để tìm lũy thừa trong C++, chúng ta cần sử dụng tới hàm pow() trong header file <cmath>. Lưu ý là chúng ta cần thêm header file này vào đầu chương trình để sử dụng được hàm này.
Và chúng ta tạo hàm kiểm tra số chính phương trong C++ với cách này như sau:
| #include <cmath>int find_square_number(int n){ //flag = 1 => số chính phương //flag = 0 => không phải số chính phương int flag = 0; //Tìm số bất kỳ nhỏ hơn hoặc bằng n mà bình phương bằng n int i = 0; while(i <= n){ if( pow( i, 2) == n ) { flag = 1; break; /*Chỉ cần tìm thấy 1 số là đủ và thoát vòng lặp*/ } i++; } return flag;} |
Chúng ta có thể gọi hàm này và sử dụng trong chương trình nhập n kiểm tra n có phải số chính phương không trong C++ như sau:
| #include <iostream>#include <cmath>using namespace std;int find_square_number(int n){ //flag = 1 => số chính phương //flag = 0 => không phải số chính phương int flag = 0; //Tìm số bất kỳ nhỏ hơn hoặc bằng n mà bình phương bằng n int i = 0; while(i <= n){ if( pow( i, 2) == n ) { flag = 1; break; /*Chỉ cần tìm thấy 1 ước số là đủ và thoát vòng lặp*/ } i++; } return flag;}int main(){ int n; cout << (">> nhap mot so tu nhien: "); cin >> n; int check = find_square_number(n); if( check == 1 ) cout << n << " la chinh phuong"; else cout << n << " khong phai la so chinh phuong"; return 0;} |
Lưu ý là số nhập từ bàn phím phải là một số tự nhiên.
Màn hình nhập liệu và kết quả kiểm tra số chính phương trong C++ sẽ như sau:
| >> nhap mot so tu nhien: 44 la so chinh phuong>> nhap mot so tu nhien: 55 khong phai la so chinh phuong>> nhap mot so tu nhien: 1616 la so chinh phuong>> nhap mot so tu nhien: 2525 la so chinh phuong |
Kiểm tra số chính phương trong C++ bằng căn bậc 2
Cách thứ 2 để kiểm tra số chính phương trong C++ là sử dụng tính chất căn bậc 2 của một số chính phương chính là một số tự nhiên.
Điều đó có nghĩa, với một số bất kỳ, nếu căn bậc 2 của nó là một số tự nhiên, thì số đó chính là số chính phương.
Để tìm căn bậc 2 trong C++, chúng ta cần sử dụng tới hàm sqrt() trong header file <cmath>. Lưu ý là chúng ta cần thêm header file này vào đầu chương trình để sử dụng được hàm này.
Để kiểm tra kết quả căn bậc 2 có phải là số tự nhiên không, chúng ta sẽ sử dụng hàm tự tạo mà Kiyoshi đã giới thiệu trong bài sau:
- Xem thêm: Kiểm tra số nguyên trong C++
Và chúng ta tạo hàm kiểm tra số chính phương trong C++ với cách này như sau:
| #include <cmath>/*Hàm kiểm tra một số có phải là số nguyên hay không*/int check_real_integer_number(float n){ //flag = 1 => số nguyên //flag = 0 => số thực int flag = 1; if (ceil(n) != floor(n)) flag = 0; return flag;}/*Hàm kiểm tra một số có phải là số chính phương hay không*/int find_square_number(int n){ //flag = 1 => số chính phương //flag = 0 => không phải số chính phương int flag = 0; //Kiểm tra căn bậc 2 của số đó có phải là số nguyên hay không if (check_real_integer_number (sqrtf(n))) flag = 1; return flag;} |
Chúng ta có thể gọi hàm này và sử dụng trong chương trình nhập n kiểm tra n có phải số chính phương không trong C++ như sau:
| #include <iostream>#include <cmath>using namespace std;int check_real_integer_number(float n){ //flag = 1 => số nguyên //flag = 0 => số thực int flag = 1; if (ceil(n) != floor(n)) flag = 0; return flag;}int find_square_number(int n){ //flag = 1 => số chính phương //flag = 0 => không phải số chính phương int flag = 0; //Kiểm tra căn bậc 2 của số đó có phải là số nguyên hay không if (check_real_integer_number (sqrtf(n))) flag = 1; return flag;}int main(){ int n; cout << (">> nhap mot so tu nhien: "); cin >> n; int check = find_square_number(n); if( check == 1 ) cout << n << " la chinh phuong"; else cout << n << " khong phai la so chinh phuong"; return 0;} |
Lưu ý là số nhập từ bàn phím phải là một số tự nhiên.
Màn hình nhập liệu và kết quả kiểm tra số chính phương trong C++ sẽ như sau:
| >> nhap mot so tu nhien: 44 la so chinh phuong>> nhap mot so tu nhien: 55 khong phai la so chinh phuong>> nhap mot so tu nhien: 1616 la so chinh phuong>> nhap mot so tu nhien: 2525 la so chinh phuong |
Liệt kê tất cả các số chính phương nhỏ hơn n
Sử dụng một trong 2 phương pháp ở trên, chúng ta có thể liệt kê tất cả các số chính phương nhỏ hơn n bằng C++.
Và dưới đây là ví dụ về chương trình liệt kê tất cả các số chính phương nhỏ hơn n trong C++:
| #include <iostream>#include <cmath>using namespace std;int find_square_number(int n){ //flag = 1 => số chính phương //flag = 0 => không phải số chính phương int flag = 0; //Tìm số bất kỳ nhỏ hơn n mà bình phương bằng n int i = 0; while(i <= n){ if( pow( i, 2) == n ) { flag = 1; break; /*Chỉ cần tìm thấy 1 ước số là đủ và thoát vòng lặp*/ } i++; } return flag;}int main(){ int n; cout << (">> nhap mot so n: "); cin >> n; int i = 0, check; while ( i < n){ check = find_square_number(i); if( check == 1 ) cout << i <<" "; ++i; } return 0;} |
Kết quả:
| >> nhap mot so n: 100 1 4 9>> nhap mot so n: 300 1 4 9 16 25 |
Tổng kết
Trên đây Kiyoshi đã hướng dẫn bạn cách kiểm tra số chính phương trong C++ cũng như cách liệt kê tất cả các số chính phương nhỏ hơn n bằng C++ rồi. Để nắm rõ nội dung bài học hơn, bạn hãy thực hành viết lại các ví dụ của ngày hôm nay nhé.
Và hãy cùng tìm hiểu những kiến thức sâu hơn về C++ trong các bài học tiếp theo.
URL Link
https://laptrinhcanban.com/cpp/lap-trinh-cpp-co-ban/so-trong-cpp/kiem-tra-so-chinh-phuong-trong-cpp/
Từ khóa » Số Chính Phương Là Gì C++
-
Kiểm Tra Số Chính Phương Trong C/C++ - Lập Trình Không Khó
-
Thuật Toán Kiểm Tra Số Chính Phương C++ - Freetuts
-
Kiểm Tra Số Chính Phương Trong C/C++ - Check Square Number
-
Số Chính Phương Là Gì? Cách Tính Số Chính Phương Trong C++, Pascal
-
Huật Toán Kiểm Tra Số Chính Phương C++ - Huật Toán Căn Bản
-
Chương Trình Kiểm Tra Số Chính Phương Trong Lập Trình C/C++
-
Thuật Toán Kiểm Tra Số Chính Phương C++
-
Bài Toán Số Chính Phương Trong Toán Và Tin Học - Đọc Tài Liệu
-
Số Chính Phương Là Gì C++ Là Gì (tìm Hiểu Các Thông Tin Và Vấn đề ...
-
Số Chính Phương Là Gì ? Các Hàm Tìm Số Chính Phương
-
Hàm Tính Trung Bình Các Số Chính Phương Có Trong Mảng Code C/C++
-
Thuật Toán Kiểm Tra Số Chính Phương C++
-
Bài Tập C++: Viết Chương Trình, Hàm Kiểm Tra Số Chính Phương
-
Thuật Toán Kiểm Tra Số Chính Phương C++
-
Số Chính Phương Là Gì? Tính Chất Của Số Chính Phương
-
Kiểm Tra Một Số Có Phải Số Chính Phương Trong C | Lập Trình Từ Đầu
-
Tính Trung Bình Cộng Các Số Chính Phương Trong Mảng - Hỏi Đáp
-
[Basic-DSAA] Giải Thuật Sắp Xếp - Bài Tập: Dãy Số Chính Phương.