Trả về dict kết quả sau khi cập nhật dict có số phần tử ít hơn cho dict có phần tử nhiều hơn. (Tham số là 2 dict)

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

0.0 (0 đánh giá)
Tạo bởi Kteam Cập nhật lần cuối 23:41 12-11-2021 2.929 lượt xem 3 bình luận
Tác giả/Dịch giả: TrongPhuCBL49 Kteam
Học nhanh

Danh sách bài học

Trả về dict kết quả sau khi cập nhật dict có số phần tử ít hơn cho dict có phần tử nhiều hơn. (Tham số là 2 dict)

Kiến thức cần có

  • Khởi tạo dict() trong Python
  • Cấu trúc lặp trong Python
  • Biến và kiểu dữ liệu
  • Hàm trong Python
  • Hàm zip() trong Python
  • Các phương thức xử lý Dict trong Python:
    • Dict Constructor
    • update()

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

  • Gồm bốn dòng:
    • Dòng đầu tiên chứa các phần tử key của dict thứ nhất. Các phần tử cách nhau bởi khoảng trắng
    • Dòng thứ hai chứa các phần tử value của dict thứ nhất. Các phần tử cách nhau bởi khoảng trắng
    • Dòng thứ ba chứa các phần tử key của dict thứ hai. Các phần tử cách nhau bởi khoảng trắng
    • Dòng thứ tư chứa các phần tử value của dict thứ hai. 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ị dict theo yêu cầu đề bài

Lưu ý:

  • Nếu số lượng key và value không bằng nhau thì xuất thông báo: Vui long nhap so luong key va value bang nhau!

Ví dụ:

  • Input 1:
1 2 3 4
mot hai ba bon
1 2 3
1 2 3
  • Output 1:
{'1': '1', '2': '2', '3': '3', '4': 'bon'}

  • Input 2:
1 2 3
mot hai ba
1 2 3 4
1 2 3 4
  • Output 2:
{'1': 'mot', '2': 'hai', '3': 'ba', '4': '4'}

  • Input 3:
1 2 3
mot hai ba
1 2 3
1 2 3
  • Output 3:
{'1': '1', '2': '2', '3': '3'}

  • Input 4:


1 2 3
mot hai ba
  • Output 4:
{'1': 'mot', '2': 'hai', '3': 'ba'}

  • Input 5:
1 2
1 2 3 4

  • Output 5:
Vui long nhap so luong key va value bang nhau!

Gợi ý

  • Định nghĩa hàm nhap_dict để nhập dict từ 2 list key, value nhập từ bàn phím (tham khảo Bài 9.2)
  • Định nghĩa hàm update_dict với tham số truyền vào là 2 dict:
    • Sử dụng cấu trúc rẽ nhánh và hàm len() để so sánh số lượng phần tử của 2 dict
    • Sử dụng phương thức update() để cập nhật dict theo yêu cầu đề bài
    • Trả về dict kết quả cho hàm
  • Gọi hàm nhap_dict để nhập 2 dict từ bàn phím
  • Gọi hàm update_dict và truyền vào tham số cần thiết.
  • Sử dụng hàm print() để hiển thị dict ra màn hình.

Code mẫu

def nhap_dict():
    listKey = input().split()
    listValue = input().split()

    if len(listKey) != len(listValue):
        print("Vui long nhap so luong key va value bang nhau!")
        return None

    dictKetQua = dict(zip(listKey, listValue))
    return dictKetQua

def update_dict(dictA, dictB):
    #So sanh so phan tu 2 dict
    if len(dictA) < len(dictB):
        #Cap nhat dict it phan tu hon cho dict nhieu phan tu hon
        dictB.update(dictA)
        return dictB

    dictA.update(dictB)
    return dictA

dictA = nhap_dict()
dictB = nhap_dict()

if dictA is not None and dictB is not None:
    dictKetQua = update_dict(dictA, dictB)
    print(dictKetQua)

Kết luận

Trong bài này, Kteam đã hướng dẫn bạn cách  VIẾT HÀM TRẢ VỀ DICT KẾT QUẢ SAU KHI CẬP NHẬT DICT CÓ SỐ PHẦN TỬ ÍT HƠN CHO DICT CÓ PHẦN TỬ NHIỀU HƠN. (THAM SỐ LÀ 2 DICT). 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Ề DICT KẾT QUẢ SAU KHI LOẠI BỎ CÁC PHẦN TỬ CÓ VALUE TRÙNG NHAU (THAM SỐ LÀ 1 DICT).

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 Trả về dict kết quả sau khi cập nhật dict có số phần tử ít hơn cho dict có phần tử nhiều hơn. (Tham số là 2 dict) 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á

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:25 02-11-2024

def crated_dic(key_lst1, value_lst1, key_lst2, value_lst2):

    dic1 = {key:value for key, value in zip(key_lst1, value_lst1)}

    dic2 = {key:value for key, value in zip(key_lst2, value_lst2)}

    return dic1, dic2

 

def fun_dic(dic1:dict, dic2:dict):

    if len(dic1) > len(dic2):

        dic1.update(dic2)

        return dic1

    dic2.update(dic1)

    return dic2

 

key_lst1 = input().split()

value_lst1 = input().split()

key_lst2 = input().split()

value_lst2 = input().split()

if len(key_lst1) != len(value_lst1) or len(key_lst2) != len(value_lst2):
    print("độ dài key và value không bằng nhau")
else:

    dic1, dic2 = crated_dic(key_lst1, value_lst1, key_lst2, value_lst2)

    print(fun_dic(dic1, dic2))

kakavan đã bình luận 20:18 07-06-2024

def func(dicA,dicB):
    if len(dicA) > len(dicB):
        dicA.update(dicB)
        return dicA
    else:
        dicB.update(dicA)
        return dicB

while True:
    lstkeyA = input("Nhập danh sách key của dicA: ").split()
    lstvalA = input("Nhập danh sách value của dicA: ").split()
    lstkeyB = input("Nhập danh sách key của dicB: ").split()
    lstvalB = input("Nhập danh sách value của dicB: ").split()

    dicA = dict(zip(lstkeyA,lstvalA))
    dicB = dict(zip(lstkeyB,lstvalB))

    if len(lstkeyA) != len(lstvalA) or len(lstkeyB) != len(lstvalB):
        print("Vui lòng nhập số lượng key và value bằng nhau!")
    else:
        print(func(dicA,dicB))
        break

TayMonKhanh đã bình luận 11:10 25-07-2023

def Ketqua(key1,value1,key2,value2):

    Ds1=dict(zip(key1,value1))

    Ds2=dict(zip(key2,value2))

    if len(key1)>len(key2):

        Ds1.update(Ds2)

        return Ds1

    else:

        Ds2.update(Ds1)

        return Ds2

   

 

key1=input().split()

value1=input().split()

key2=input().split()

value2=input().split()

if len(key1)!=len(value1) or len(key2)!=len(value2):

    print("Vui long nhap so luong key va value bang nhau!")

else:

    print(Ketqua(key1,value1,key2,value2))

Không có video.