Viết hàm trả về danh sách các phần tử là số nguyên tố. (Tham số là danh sách nguyên dương).

Bài tập Python tự luyện

5.0 (1 đánh giá)
Tạo bởi Kteam Cập nhật lần cuối 23:58 11-11-2021 31.379 lượt xem 16 bình luận
Tác giả/Dịch giả: TrongPhuCBL49 Kteam
Học nhanh

Danh sách bài học

Viết hàm trả về danh sách các phần tử là số nguyên tố. (Tham số là danh sách nguyên dương).

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

Viết hàm với tham số truyền vào là một danh sách các số nguyên dương. Trả về danh sách các phần tử là số nguyên tố.


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
  • Hàm trong Python
  • Xử lý ngoại lệ (Exception Handling)
  • Các phương thức xử lý List trong Python:
  • split()
  • List Comprehension
  • Unpacking arguments

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

Gồm một dòng duy nhất chứa các phần tử là số thực của danh sách, các phần tử cách nhau bởi khoảng trắng


Định dạng đầu ra

Gồm một dòng duy nhất hiển thị các phần tử của danh sách sau khi được sắp xếp tăng dần, các phần tử cách nhau bởi khoảng trắng

Lưu ý: Nếu danh sách rỗng thì xuất thông báo: Danh sach rong

              Nếu phần tử không phải là số nguyên thì xuất thông báo: Vui long nhap cac phan tu la so nguyen!


Ví dụ

  • Input 1:
5 3 -6 7 9 -10 22 11
  • Output 1:
5 3 7 11
  • Input 2:
4 6 -3
  • Output 2:
#nothing
  • Input 3:
2
  • Output 3:
2
  • Input 4:
#nothing
  • Output 4:
Danh sach rong
  • Input 5:
4 3$ 5 kteam 8.9 3.3.4
  • Output 5:
Vui long nhap cac phan tu la so nguyen!

Gợi ý

  • Định nghĩa hàm kt_so_nguyen_to (tham khảo Bài 4.10)
  • Định nghĩa hàm ds_so_nguyen_to với tham số là danh sách số nguyên:
  • Sử dụng List Comprehension kết hợp với vòng lặp for và hàm kt_so_nguyen_to để khởi tạo list gồm các phần tử là số nguyên tố từ danh sách đã cho.
  • Trả về danh sách các số nguyên tố
  • Dùng hàm input() và hàm split() để nhập dòng đầu tiên từ bàn phím và cắt chúng thành danh sách các phần tử
  • Sử dụng cấu trúc rẽ nhánh và hàm len() để kiểm tra xem có phải là danh sách rỗng không. Xuất thông báo lỗi nếu có.
  • 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 khi ép kiểu dữ liệu
  • Đặt chương trình trong khối try.
  • Dùng hàm list() map() để ép kiểu dữ liệu của các phần tử sang số nguyên và trả về danh sách các số nguyên
  • Gọi hàm ds_so_nguyen_to và truyền vào tham số cần thiết.
  • Sử dụng kỹ thuật Unpacking arguments để hiển thị kết quả ra màn hình theo định dạng đầu ra.
  • 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

def kt_so_nguyen_to(n):
   if n < 1:
       return False       
   #Su dung vong lap for de duyet cac so tu 2 den can bac hai cua n
   for i in range(2, int(math.sqrt(n))+1):
       #Kiem tra tinh chia het
       if n % i == 0:
           return False
   return True

def ds_so_nguyen_to(danhSachSo):
   dsSoNguyenTo = [so for so in danhSachSo if kt_so_nguyen_to(so)]
   return dsSoNguyenTo

#Nhap danh sach tu ban phim
danhSach = input().split()
#Kiem tra xem danh sach co rong hay khong
if len(danhSach) == 0:
   print("Danh sach rong")
else:
   #Khoi lenh co the phat sinh loi
   try:
       #Ep kieu du lieu sang so nguyen
       danhSachSo = list(map(int, danhSach))
       #Goi thuc thi ham va truyen tham so cho ham
       dsSoNguyenTo = ds_so_nguyen_to(danhSachSo)
       #Unpacking arguments
       print(*dsSoNguyenTo)
   #Khoi lenh duoc thuc thi khi loi xay ra
   except:
       print("Vui long nhap cac phan tu la so nguyen!")

Kết luận

Trong bài này, Kteam đã hướng dẫn bạn cách viết hàm với tham số truyền vào là một danh sách các số nguyên dương. Trả về danh sách các phần tử là số nguyên tố. 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 TRẢ VỀ DANH SÁCH CÁC  PHẦN TỬ XUẤT HIỆN DUY NHẤT TRONG DANH SÁCH ĐÃ CHO. (THAM SỐ LÀ DANH SÁCH).

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

Tài liệu

Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Viết hàm trả về danh sách các phần tử là số nguyên tố. (Tham số là danh sách nguyên dương). dưới dạng file PDF trong link bên dưới.

Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com

Đừng quên likeshare để ủng hộ Kteam và tác giả nhé!

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!


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.

Nội dung bài viết

Tác giả/Dịch giả

Có niềm đam mê với thuật toán và tư duy logic. Là người cầu toàn, thích lập kế hoạch và tối ưu mọi vấn đề trong cuộc sống. Mong muốn luôn sống vui vẻ yêu đời =))) không bon chen.

Sở thích cá nhân: Đàn ca nhảy múa và đi du lịch.


Khóa học

Bài tập Python tự luyện

Serial dành cho những bạn cần luyện tập phương pháp, tu duy lập trình. Làm quen với các bài toán trong lập trình, ngẫu nhiên từ cơ bản đến nâng cao. Nội dung Serial này được phân tách chi tiết nhất có thể, nhằm giúp các bạn dễ hiểuthực hành được ngay.

Bạn nên tự làm lại từng bài tập trên video để có kết quả tốt nhất. Cùng Kteam "Luyện tập - Thử thách - không ngại khó"

Đánh giá

LongPython đã đánh giá 18:55 13-05-2021

Bình luận

Để bình luận, bạn cần đăng nhập bằng tài khoản Howkteam.

Đăng nhập
haikhongbeo993 đã bình luận 00:31 30-10-2024

# 1

def return_prime_num(s):

    prime_lst = [value  for value in s if value > 1 and all(value % i != 0 for i in range(2, int(value**0.5)+1))]

    return prime_lst

# 2

def return_prime_num1(s):

    prime_lst = []

    for value in s:

        if value < 1:

            continue

        else:

            for j in range(2, int(value**0.5)+1):

                if value % j == 0:

                    break

            else:

                prime_lst.append(value)

    return prime_lst

 

s = input()

if len(s) == 0:

    print("not value")

else:

    try:

        s = list(map(float, s.split()))

        print(*return_prime_num1(s))

    except ValueError:

        print("error")

Legend đã bình luận 15:04 03-09-2024
import math

def kt_so_nguyen_to(n):
   if n < 1:
       return False       
   #Su dung vong lap for de duyet cac so tu 2 den can bac hai cua n
   for i in range(2, int(math.sqrt(n))+1):
       #Kiem tra tinh chia het
       if n % i == 0:
           return False
   return True

def ds_so_nguyen_to(danhSachSo):
   dsSoNguyenTo = [so for so in danhSachSo if kt_so_nguyen_to(so)]
   return dsSoNguyenTo

#Nhap danh sach tu ban phim
danhSach = input().split()
#Kiem tra xem danh sach co rong hay khong
if len(danhSach) == 0:
   print("Danh sach rong")
else:
   #Khoi lenh co the phat sinh loi
   try:
       #Ep kieu du lieu sang so nguyen
       danhSachSo = list(map(int, danhSach))
       #Goi thuc thi ham va truyen tham so cho ham
       dsSoNguyenTo = ds_so_nguyen_to(danhSachSo)
       #Unpacking arguments
       print(*dsSoNguyenTo)
   #Khoi lenh duoc thuc thi khi loi xay ra
   except:
       print("Vui long nhap cac phan tu la so nguyen!")

 

kakavan đã bình luận 10:16 04-06-2024

def func(intlist):
    [intlist.remove(x) for x in intlist if x <= 1]

    for num in intlist:
        if (num == 2 or num == 3) or (num % 2 != 0 and num % 3 != 0):
            print(num,end=' ')   

while True:
    try:
        intlist = list(map(int,input("Nhập 1 danh sách: ").split()))

        if intlist == []:
            print("Danh sách rỗng!")
        else:
            func(intlist)
            break
    except:
        print("Vui lòng nhập các phần tử là số nguyên!")

vandathl đã bình luận 14:00 28-07-2023
#CÁCH 01:
def func1_(ds):
    ds_new=[]
    for i in ds:
        for j in range(2,(i//2)+1):
            if (i%j)==0:
                ds_new.append(i)      #lập danh sách ko phải số nguyên tố
                break

    for n in ds_new:
        ds.pop(ds.index(n))           #pop những số trong ds ko phải số nt ra khỏi ds ban đầu  
    return ds

#CÁCH 02:

import math
def check_(n):
    if n<1:
        return False
    for i in range(2,int(math.sqrt(n))+1):
        if n%i==0:
            return False
    return True
def func2_(ds1):
    dsnt=[so for so in ds1 if check_(so)]
    return dsnt

s=input().split()
s_new=list(map(int,s))
if len(s)==0:
    print("Danh sách rỗng")
else:
    try:
        print("CÁCH 01: Danh sách số nguyên tố là:",func1_(s_new))
        print("CÁCH 02: Danh sách số nguyên tố là:",func2_(s_new))
    except:
        print("Vui lòng nhập dãy số nguyên dương")
TayMonKhanh đã bình luận 08:44 03-07-2023

def Xetsonguyento(so):

    if so<=1:

        return False

    else:

        return all(so%i!=0 for i in range(2,so))

def Ketqua(a):

    Day_so=[so for so in a if Xetsonguyento(so)]

    return Day_so

 

cờ=False

try:

    a=input("Nhập số: ")

    a=list(map(int,a.split()))

    cờ=True

except:

    print("Nhập số thực")

if cờ:

    if len(a)==0:

        print("Rỗng")

    else:

        Day_so=Ketqua(a)

        print(*Day_so)

Không có video.