Viết hàm trả lại danh sách n phần tử, lặp lại danh sách truyền vào. (Tham số là danh sách và số tự nhiên n)

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:59 11-11-2021 7.093 lượt xem 18 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ả lại danh sách n phần tử, lặp lại danh sách truyền vào. (Tham số là danh sách và số tự nhiên n)

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 và số tự nhiên n. Trả về danh sách n phần tử bằng cách lặp lại danh sách được truyền vào.


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
  • Toán tử *

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

Gồm hai dòng:

  • Dòng đầu tiên chứa các phần tử của danh sách, các phần tử cách nhau bởi khoảng trắng.
  • Dòng thứ hai chứa số tự nhiên n.

Đị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 input nằm ngoài định dạng đầu vào thì xuất thông báo: Vui long nhap cac phan tu la so thuc!


Ví dụ

  • Input 1:
1 hai 3 bon nam
7
  • Output 1:
1 hai 3 bon nam 1 hai
  • Input 2:
Kteam Kteam 2021 Chuc Mung Nam Moi
3
  • Output 2:
Kteam Kteam 2021
  • Input 3:
Kteam Kteam 2021 Chuc Mung Nam Moi
0
  • Output 3:
#nothing
  • Input 4:
#nothing
  • Output 4:
Danh sach rong
  • Input 5:
4 3$ 5 kteam 8.9 3.3.4
  • Output 5:
Dinh dang dau vao khong hop le!

Gợi ý

  • Định nghĩa hàm nhan_ban_danh_sach với tham số là danh sách bất kỳ và số tự nhiên n:
  • Sử dụng hàm len() để lấy số phần tử của danh sách
  • Tính toán số lần cần nhân bản bằng cách chia lấy phần nguyên n cho số phần tử của danh sách, cộng 1
  • Sử dụng toán tử * để nhân bản danh sách với số lần tính được phía trên
  • Sử dụng kỹ thuật cắt list để cắt đúng n phần tử từ danh sách
  • Trả về danh sách kết quả
  • 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 input() kết hợp hàm int() để nhập n từ bàn phím và ép kiểu dữ liệu sang số nguyên
  • Gọi hàm nhan_ban_danh_sach 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

def nhan_ban_danh_sach(danhSach, n):
   #Su dung ham len() de lay so luong phan tu cua danh sach
   soPhanTu = len(danhSach)
   #Tinh toan so lan toi thieu can lap lai danh sach
   soLanNhanBan = n // soPhanTu + 1
   #Su dung toan tu * de lap danh sach voi so lan mong muon
   dsNhanBan = danhSach*soLanNhanBan
   #Cat danh sach cho dung n phan tu
   dsNPhanTu = dsNhanBan[:n]
   return dsNPhanTu
  

#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:
       #Nhap gia tri n tu ban phim
       #Ep kieu du lieu sang so nguyen
       n = int(input())
       #Goi thuc thi ham va truyen tham so cho ham
       dsKetQua = nhan_ban_danh_sach(danhSach, n)
       #Unpacking arguments
       print(*dsKetQua)

   #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 hàm với tham số truyền vào là một danh sách và số tự nhiên n. Trả về danh sách n phần tử bằng cách lặp lại danh sách được truyền vào.. Trả về danh sách các phần tử lẻ. 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 KẾT QUẢ CHÈN "KTEAM" VÀO CÁC VỊ TRÍ CHIA HẾT CHO N.

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ả lại danh sách n phần tử, lặp lại danh sách truyền vào. (Tham số là danh sách và số tự nhiên n) 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á

TankAnk đã đánh giá 17:32 18-09-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 10:37 31-10-2024

def retur_(s:list, n):

    if n > len(s):

        s = s * (n//len(s) + 1)

    result = [value for value in s]

    return result[0:n]

 

s = input().split()

if len(s) == 0:

    print("empty list")

else:

    try:

        n = int(input())

        print(*retur_(s, n))

    except ValueError:

        print("error")

kakavan đã bình luận 11:31 04-06-2024

from math import ceil

def func(lst,n):
    x_time = ceil(n/len(lst))
    lst = lst*x_time

    [print(lst[i],end=' ') for i in range(n)]

while True:
    try:
        lst = input("Nhập 1 danh sách: ").split()
        n = int(input("Nhập 1 số tự nhiên: "))

        if lst == []:
            print("Danh sách rỗng!")
        else:
            func(lst,n)
            break
    except:
        print("Định dạng đầu vào không hợp lệ!")

TayMonKhanh đã bình luận 08:07 04-07-2023

def Ketqua(a,n):

    Tong=[]

    while n>len(a):

        Tong=Tong+a

        n=n-len(a)

    if n<len(a) or n==len(a):

        Tong=Tong+a[0:n]

    return Tong

 

cờ=False

try:

    a=input("Nhập chuỗi: ")

    n=int(input("Nhập số tự nhiên: "))

    cờ=True

except:

    print("Định dạng kh hợp lệ")

if cờ:

    a=a.split()

    Day=Ketqua(a,n)

    print(*Day)

Tùng đã bình luận 23:58 06-03-2023
def xu_ly(danh_sach, so):
	try:
		so = int(so)
		danh_sach = danh_sach.split()
		danh_sach = danh_sach * so
		for i in range(so):
			print(danh_sach[i], end = " ")
	except:
		print("Đầu vào không hợp lệ")

def main():
	a = input("Nhập chuỗi cần kiểm tra: ")
	b = input("Nhập số tự nhiên n: ")
	xu_ly(a, b)

main()

 

hoankameha1234 đã bình luận 16:26 29-11-2021

s = input("Select S: ").split()
n = int(input("How many times do you want to print: "))
def times_print(s,n):
    times_duplicate = int(n/len(s))
    print(times_duplicate)
    the_words = n%len(s)
    print(the_words)
    new_list= times_duplicate*s
    for i in range(the_words):
        new_list.append(s[i])
    return new_list

print(*times_print(s,n))        


 

Không có video.