Viết hàm hiển thị ra màn hình tên và quốc tịch tương ứng với vị trí trong danh sách. (Tham số là 2 danh sách).

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 6.904 lượt xem 11 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 hiển thị ra màn hình tên và quốc tịch tương ứng với vị trí trong danh sách. (Tham số là 2 danh sách).

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

Viết hàm với tham số truyền vào là hai danh sách cùng kích thước: danh sách tên và danh sách quốc tịch. Hiển thị ra màn hình tên và quốc tịch tương ứng với vị trí trong danh sách.


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
  • Hàm zip()
  • Các phương thức xử lý List trong Python:
  • split()
  • List Comprehension
  • Unpacking arguments
  • count()

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

Gồm hai dòng:

Gồm n dòng, với n là số lượng phần tử của danh sách:

  • Dòng đầu tiên chứa danh sách tên, các phần tử cách nhau bởi dấu ‘,’
  • Dòng thứ hai chứa danh sách quốc tịch tương ứng với dữ liệu danh sách tên, các phần tử cách nhau bởi dấu ‘,’

Định dạng đầu ra

  • Dòng thứ i hiển thị tên và quốc tịch của người thứ i đã được xóa khoảng trống thừa, hai giá trị cách nhau bởi dấu ‘ - ‘

Lưu ý: Nếu hai danh sách không cùng kích thước thì xuất thông báo: Vui long nhap hai danh sach cung kich thuoc!


Ví dụ

  • Input 1:
Trang  Ti  , Suu  Eo  ,  Ca  Meo, Dan Beo
Viet Nam, Thai Lan,  Lao , Anh
  • Output 1:
Trang Ti - Viet Nam
Suu Eo - Thai Lan
Ca Meo - Lao
Dan Beo - Anh
  • Input 2:
Kteam
My, Nga, Trung Quoc
  • Output 2:
Vui long nhap hai danh sach cung kich thuoc!

Gợi ý

  • Định nghĩa hàm xoa_khoang_trang_thua (tham khảo Bài 5.10)
  • Định nghĩa hàm in_danh_sach với tham số là danh sách tên và danh sách quốc tịch tương ứng:
  • Sử dụng List Comprehension kết hợp với vòng lặp for và hàm xoa_khoang_trang_thua để xóa khoảng trắng thừa của các phần tử trong hai danh sách.
  • Sử dụng vòng lặp for và hàm zip() để ghép phần tử hai danh sách theo thứ tự tương ứng.
  • Hiển thị kết quả ra màn hình theo định dạng đầu ra yêu cầu
  • Dùng hàm input() và hàm split() với tham số là dấu ‘,’ để nhập hai danh sách từ bàn phím và cắt chúng ra thành list, ngăn cách bởi dấu ‘,’
  • Kiểm tra xem hai danh sách có cùng kích thước hay chưa. Xuất thông báo lỗi nếu có.
  • Gọi hàm in_danh_sach và truyền vào tham số cần thiết.

Code mẫu

def xoa_khoang_trang_thua(s):
   #Su dung phuong thuc strip() de xoa khoang trang o dau va cuoi chuoi
   s = s.strip()
   #Su dung vong lap while de lap cho toi khi nao het khoang trang thua
   while "  " in s:
       #Su dung phuong thuc replace() de thay the 2 khoang trang thanh 1 khoang trang
       s = s.replace("  ", " ")
   return s

def in_danh_sach(dsTen,  dsQuocTich):
   #Su dung List Comprehension de xoa cac khoang trang thua cua cua phan tu
   dsTen = [xoa_khoang_trang_thua(ten) for ten in dsTen]
   dsQuocTich = [xoa_khoang_trang_thua(quocTich) for quocTich in dsQuocTich]
   #Su dung vong lap for voi ham zip() de ghep 2 chuoi voi nhau
   for ten, quocTich in zip(dsTen, dsQuocTich):
       print(ten + " - " + quocTich)

#Nhap danh sach tu ban phim
#Su dung ham split(',') de cat chuoi dua vao dau ','
dsTen = input().split(',')
dsQuocTich = input().split(',')

#Kiem tra danh sach co cung kich thuoc hay khong
if len(dsTen) != len(dsQuocTich):
   print("Vui long nhap hai danh sach cung kich thuoc!")
else:   
   #Goi ham va truyen cac tham so can thiet
   in_danh_sach(dsTen, dsQuocTich)

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à hai danh sách cùng kích thước: danh sách tên và danh sách quốc tịch. Hiển thị ra màn hình tên và quốc tịch tương ứng với vị trí trong danh sách. 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Ả NHÂN SỐ ĐẦU TIÊN CỦA DANH SÁCH 1 VỚI SỐ CUỐI CÙNG CỦA DANH SÁCH 2 . (THAM SỐ LÀ 2 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 hiển thị ra màn hình tên và quốc tịch tương ứng với vị trí trong danh sách. (Tham số là 2 danh sách). 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á

lephuduc đã đánh giá 22:05 07-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
kakavan đã bình luận 09:53 05-06-2024

def delspace(s):
    while '  ' in s:
        s = s.replace('  ',' ')

    s = s.strip(' ')

    return s

def namenation(lst_1,lst_2):
    lst_A = [delspace(s) for s in lst_1]
    lst_B = [delspace(s) for s in lst_2]

    for i in range(len(lst_A)):
        print("{} - {}".format(lst_A[i],lst_B[i]))        

while True:
    lst_1 = input("Nhập danh sách 1: ").split(',')
    lst_2 = input("Nhập danh sách 2: ").split(',')

    if len(lst_1) != len(lst_2):
        print("Vui lòng nhập hai danh sách cùng kích thước!")
    else:
        namenation(lst_1,lst_2)
        break

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

def Ketqua(Ten,Ketqua):

    Dau_gach=["-"]*len(Ten)

    Day=zip(Ten,Dau_gach,Ketqua)

    for t in Day:

        print(*t,end="\n")

 

Ten=input("Nhập dãy tên: ").split(",")

Quoctich=input("Nhập quốc tịch: ").split(",")

if len(Ten)==len(Quoctich):

    Ten=[x.strip() for x in Ten ]

    Quoctich=[i.strip() for i in Quoctich ]

    Ketqua(Ten,Quoctich)

else:

    print("Vui lòng nhập đúng kt")

 

Tùng đã bình luận 23:17 07-03-2023
def xu_ly(a,b):
	a = a.split(",")
	b = b.split(",")
	if len(a) == len(b):
		for i in range(len(a)):
			xoa_space(a,i)
			xoa_space(b,i)
			print(a[i] + ' - ' + b[i])
	elif len(a) != len(b):
		print('Vui lòng nhập danh sách cùng kích thước')
def xoa_space(stri, i):
	stri[i] = stri[i].strip()
	stri[i] = stri[i].replace('  ', ' ')
	return stri[i]



def main():
	a = input('Mời nhập tên: ')
	b = input('Mời nhập quốc tịch: ')
	xu_ly(a,b)
main()

 

NhuwLikesVeggies đã bình luận 10:31 23-07-2022
def name_and_nationality(s1, s2):
    for i in range(len(s1)):
        print("{} - {}".format(s1[i].strip(), s2[i].strip()))
s1 = input().split(",")
s2 = input().split(",")
if len(s1) != len(s2):
    print("Vui lòng nhập hai danh sách có cùng kích thước!")
else:
    name_and_nationality(s1, s2)

 

ntnhan.0705 đã bình luận 10:48 11-10-2021
def del_space(string):
    string = string.split(',')
    for i in range(len(string)):
        string[i] = ' '.join(string[i].split())
    return string

def xu_ly(string1,string2):
    lst1 = del_space(string1)
    lst2 = del_space(string2)
    if len(lst1) != len(lst2):
        return 'Vui lòng nhập 2 list có cùng số phần tử'
    else:
        for ten,quocGia in zip(lst1,lst2):
            print(ten, '-', quocGia)

s1 = 'Trang  Ti  , Suu  Eo  ,  Ca  Meo, Dan Beo'
s2 = 'Viet Nam, Thai Lan,  Lao , Anh'

if __name__ == '__main__':
    print(xu_ly(s1,s2))

 

Không có video.