In ra dãy số nguyên to python



Nội dung chính

  • Đề bài
    • Định nghĩa
  • Ví dụ số nguyên tố
  • Lời giải

Bài tập Python: Viết chương trình liệt kê n số nguyên tố đầu tiên trong Python. Số nguyên dương n được nhập từ bàn phím.


Định nghĩa

Số nguyên tố là số lớn hơn 1 và chỉ chia hết cho 1 và chính nó.
Ví dụ: 2, 3, 5, 7, 11, 13, 17, … là những số nguyên tố.
Chú ý: Số 0 và 1 không phải là số nguyên tố. Chỉ có số 2 là số nguyên tố chẵn, tất cả các số chẵn khác không phải là số nguyên tố vì chúng chia hết cho 2.



Ví dụ số nguyên tố

Danh sách số nguyên tố nhỏ hơn 100:

In ra dãy số nguyên to python


Lời giải

import math

"""
 * check so nguyen to
 * 
 * @author viettuts.vn
 * @param n: so nguyen duong
 * @return true la so nguyen so, 
 *         false khong la so nguyen to
"""
def isPrimeNumber(n):
    # so nguyen n < 2 khong phai la so nguyen to
    if (n < 2):
        return False;

    # check so nguyen to khi n >= 2
    squareRoot = int(math.sqrt(n));
    for i in range(2, squareRoot + 1):
        if (n % i == 0):
            return False;
    return True;

n = int(input("Nhập số nguyên dương n = "));
print (n, "Số nguyên tố đầu tiên là:");
dem = 0; # đếm số số nguyên tố
i = 2;   # tìm số nguyên tố bắt dầu từ số 2
sb = "";
while (dem < n):
    if (isPrimeNumber(i)):
        sb = sb + str(i) + " ";
        dem = dem + 1;
    i = i + 1;
print(sb);

Kết quả:

Nhập số nguyên dương n = 10
10 Số nguyên tố đầu tiên là:
2 3 5 7 11 13 17 19 23 29 



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

Viết chương trình nhập vào từ bàn phím hai số tự nhiên a và b (a <= b). Hiển thị ra màn hình các số nguyên tố trong đoạn từ a đến b.


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 hai dòng:

  • Dòng đầu tiên chứa số tự nhiên a
  • Dòng thứ hai chứa số tự nhiên b

Lưu ý: a <= b


Định dạng đầu ra

Gồm một dòng duy nhất hiển thị các số nguyên tố trong đoạn [a, b]. Các số cách nhau một khoảng trắng.

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

              Nếu a > b thì xuất thông báo: So thu nhat lon hon so thu hai!

              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ụ:

  • Input 1:
2
17
  • Output 1:
2 3 5 7 11 13 17
  • Input 2:
7620
7760
  • Output 2:
7621 7639 7643 7649 7669 7673 7681 7687 7691 7699 7703 7717 7723 7727 7741 7753 7757 7759
  • Input 3:
-5
8
  • Output 3:
Vui long nhap cac so tu nhien!
  • Input 4:
15
10
  • Output 4:
So thu nhat lon hon so thu hai!
  • Input 5:
Kteam
  • Output 5:
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 hai giá trị a, b từ bàn phím.
  • Chuyển hai giá trị mới nhận được sang kiểu số nguyên, 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 a, b nhỏ hơn 0 và a > b. 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ừ a đến b
    • Với mỗi số được duyệt qua, kiểm tra số đó có phải là số nguyên tố không (Tham khảo Bài 3.16)
    • Nếu là số nguyên tố thì dùng hàm print() kết hợp với tham số end để hiển thị kết quả theo định dạng đầu ra yêu cầu
  • 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

import math

#Khoi lenh co the phat sinh loi
try:
   #Nhap hai so tu ban phim
   #Ep kieu du lieu sang so nguyen
   a = int(input())
   b = int(input())
  
   #Su dung cau truc re nhanh xu ly cac truong hop
   if a < 0 or b < 0:
       print("Vui long nhap so tu nhien!")
   elif a > b:
       print("So thu nhat lon hon so thu hai!")
   else:
       #Su dung vong lap for duyet cac so tu a den b
       for i in range(a, b + 1):
           if i > 1:       
               #Su dung vong lap for de duyet cac so tu 2 den can bac hai cua i
               for j in range(2, int(math.sqrt(i))+1):
                   #Kiem tra tinh chia het
                   if i % j == 0:
                       #Thoat vong lap
                       break
               #Neu khong thoat vong lap thi khoi lenh else se duoc thuc hien
               else:
                   print(i, end=' ')
#Khoi lenh duoc thuc thi khi loi xay ra
except:
   print("Dinh dang dau vao khong hop le!")

Kết luận

Trong bài này, Kteam đã hướng dẫn bạn cách viết chương trình nhập vào từ bàn phím hai số tự nhiên a và b (a <= b). Hiển thị ra màn hình các số nguyên tố trong đoạn từ a đến b. 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 HÀM HIỂN THỊ CÂU THEO MẪU. (VỚI THAM SỐ LÀ {TEN} VÀ {TUOI} ).

Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của bạn để phát triển bài viết tốt hơn. Đừng quên " Luyện tập - Thử Thách - Không ngại khó!"


Tải xuống

Project

Nếu việc thực hành theo hướng dẫn không diễn ra suôn sẻ như mong muốn. Bạn cũng có thể tải xuống PROJECT THAM KHẢO ở link bên dưới!

In ra dãy số nguyên to python


Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.