Kiểm tra số trong python

Hãy viết chương trình kiểm tra số chính phương bằng Python, qua bài này sẽ giúp bạn hiểu được số chính phương là gì, cũng như thuật toán để kiểm tra số chính phương bằng Python.

Bài giải

-------------------- ######## --------------------

Số chính phương là số có giá trị bằng tổng bình phương của một số nguyên nào đó. Ví dụ số 4 là số chính phương vì nó 4 = 2^2.

Để giải bài này thì bạn chỉ cần kiểm tra trong phạm vi từ 1 đến N xem có số nào bình phương lên sẽ bằng N hay không. Nếu có thì N là số chính phương, ngược lại thì không phải.

Bài toán cần xử lý

Viết chương trình kiểm tra n có phải số nguyên tố không. Với n là số tự nhiên nhập từ bàn phím.

Kiến thức cần có

  • Hàm input[] và hàm print[]
  • Cấu trúc lặp trong Python
  • Cấu trúc rẽ nhánh trong Python
  • Biến và kiểu dữ liệu
  • Xử lý ngoại lệ [Exception Handling]

Định dạng đầu vào

Gồm một dòng duy nhất chứa số tự nhiên n 

Định dạng đầu ra

Gồm một dòng duy nhất hiển thị như sau:

Nếu n là số nguyên tố:

  • Nếu n là số nguyên tố: {n} la so nguyen to!
  • Nếu n không phải là số nguyên tố: {n} khong la so nguyen to!

{n} khong la so nguyen to!

  • Với {n} là số tự nhiên nhập từ bàn phim

Lưu ý: Nếu n nhỏ hơn 0 thì xuất thông báo: Vui long nhap so tu nhien!

              Nếu input nằm ngoài định dạng đầu vào thì xuất thông báo: Dinh dang dau vao khong hop le!

Ví dụ:

0
0 khong la so nguyen to!
174567
174567 khong la so nguyen to!
113
113 la so nguyen to!
-1457
Vui long nhap so tu nhien!
Kteam
Dinh dang dau vao khong hop le!

Gợi ý

  • Sử dụng cấu trúc Xử lý ngoại lệ để xử lý các trường hợp gây ra lỗi
  • Đặt toàn bộ chương trình trong khối try.
  • Dùng hàm input[] để nhập giá trị n và x từ bàn phím.
  • Chuyển giá trị mới nhận được sang kiểu số thực và số nguyên tương ứng, vì các giá trị nhận được từ hàm input[] mặc định sẽ ở kiểu chuỗi.
  • Sử dụng cấu trúc rẽ nhánh để xử lý trường hợp n nhỏ hơn hoặc bằng 0. Hiển thị thông báo lỗi nếu có.
  • Sử dụng vòng lặp for để duyệt các số từ 2 đến căn bậc hai của n:
    • Sử dụng cấu trúc rẽ nhánh để kiểm tra có phải là ước số của n hay không
    • Nếu có một số là ước của n thì:
      • Dùng hàm break thoát vòng lặp
      • Hiển thị thông báo n không phải là số nguyên tố
  • Nếu trong khoảng 2 đến căn bậc hai của n không có số nào là ước của n thì thông báo n là số nguyên tố
  • Lỗi sẽ phát sinh ở lệnh ép kiểu nếu định dạng đầu vào không hợp lệ. Dùng lệnh except để bắt lỗi:
  • Dùng hàm print[] hiển thị thông báo lỗi ra màn hình

Code mẫu

0 khong la so nguyen to!
0

Kết luận

Trong bài này, Kteam đã hướng dẫn bạn cách viết chương trình kiểm tra n có phải số nguyên tố không. Với n là số tự nhiên nhập từ bàn phím. Thêm bài giải của bạn vào phần bình luận để được Kteam review code và fix lỗi [nếu có] trong livestream của khóa học này.

Ở bài tiếp theo, chúng ta sẽ cũng nhau học cách VIẾT CHƯƠNG TRÌNH HIỂN THỊ RA MÀN HÌNH CÁC SỐ NGUYÊN TỐ TRONG ĐOẠN TỪ A ĐẾN B. [VỚI A> nhap mot so: 1.11
1.11 la so thuc

>> nhap mot so: 1
1.0 la so nguyen

>> nhap mot so: -1.234
-1.234 la so thuc

Liệt kê và tính tổng tất cả các số nguyên

Sử dụng phương pháp ở trên, chúng ta có thể liệt kê và tính tổng tất cả các số nguyên bằng python.

Và dưới đây là ví dụ về chương trình liệt kê và tính tổng tất cả các số nguyên trong python:

import math
def check_prime_number[n]:



flag = 1;
if [math.ceil[n] != math.floor[n]]:
flag = 0;
return flag;

nums = [5, 4.1, 7.2, 2, 8.9, 7, 3]
total=0
for i in nums:
check = check_prime_number[i]
if[ check == 1 ] :
print[i]
total += i
print["Tong cac so nguyen trong mang: ",total]

Kết quả:

5
2
7
3
Tong cac so nguyen trong mang: 17

Tổng kết

Trên đây Kiyoshi đã hướng dẫn bạn cách kiểm tra số nguyên trong python, cũng như cách liệt kê và tính tổng tất cả các số nguyên bằng python 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é.

Chủ Đề