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)
Bài tập Python tự luyện

Danh sách bài học
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)
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
- copy()
- pop()
Đị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 key. 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ử của danh sách value. 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 5
1 1 2 2 3
- Output 1:
{'1': '1', '3': '2', '5': '3'}
- Input 2:
1 2 3 4 5
kteam kteam kteam kteam kteam
- Output 2:
{'1': 'kteam'}
- Input 3:
1 2 3 4 5
mot hai ba bon nam
- Output 3:
{'1': 'mot', '2': 'hai', '3': 'ba', '4': 'bon', '5': 'nam'}
- Input 4:
- Output 4:
{}
- 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 xoa_ptu_trung_value với tham số truyền vào là dict:
- Sử dụng danh sách listValue để lưu trữ các value
- Sử dụng phương thức copy() để sao chép các phần tử của dict truyền vào cho dict kết quả
- Sử dụng vòng lặp for và phương thức items()
để duyệt qua các phần tử của dict kết quả.
- Nếu value đã chứa trong listValue thì sử dụng phương thức pop() để loại bỏ phần tử đó ra khỏi dict kết quả.
- Nếu không thì thêm value vào listValue.
- Trả về dict kết quả cho hàm
- Gọi hàm nhap_dict để nhập dict từ bàn phím
- Gọi hàm xoa_ptu_trung_value 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 xoa_ptu_trung_value(dictA):
listValue = list()
#Su dung phuong thuc copy de copy cac phan tu cua dictA
dictKetQua = dictA.copy()
for key, value in dictA.items():
if value in listValue:
#Su dung phuong thuc pop de bo di phan tu co key
dictKetQua.pop(key)
else:
listValue.append(value)
return dictKetQua
dictA = nhap_dict()
if dictA is not None:
dictKetQua = xoa_ptu_trung_value(dictA)
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 LOẠI BỎ CÁC PHẦN TỬ CÓ VALUE TRÙNG NHAU (THAM SỐ LÀ 1 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Ề KẾT QUẢ GỒM CHUỖI CÁC KEY ĐƯỢC NỐI VỚI NHAU BẰNG DẤU "-" VÀ TỔNG CÁC VALUE. (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 loại bỏ các phần tử có value trùng nhau (Tham số là 1 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 like và share để ủng hộ Kteam và tác giả nhé!

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
Khóa học
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ểu và thự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ó"
def created_dic():
key_l, value_l = input().split(), input().split()
if len(key_l) != len(value_l):
print("the length of key_list and value_list is not equal")
return None
return dict(zip(key_l, value_l))
def fun_dic(dic):
result = {}
lst_value = set()
for key, value in dic.items():
if value not in lst_value:
result[key] = value
lst_value.add(value)
return result
dic = created_dic()
if dic is not None:
print(fun_dic(dic))
def func(dic):
result_dic = {}
[result_dic.update({key:value}) for key,value in dic.items() if not value in result_dic.values()]
return result_dic
while True:
lstkey = input("Nhập danh sách key: ").split()
lstval = input("Nhập danh sách value: ").split()
dic = dict(zip(lstkey,lstval))
if len(lstkey) != len(lstval):
print("Vui lòng nhập số lượng key và value bằng nhau!")
else:
print(func(dic))
break
key=input().split()
value=input().split()
if len(key)==len(value):
dict1=dict(zip(key,value))
dict2={}
for k,v in dict1.items():
if v not in dict2.values():
dict2[k]=v
print(dict2)
else:
print("vui long nhap so luong key và value bang nhau")
def ketqua(dictA):
dic1=dictA.copy()
dicmoi=dictA.copy()
for key,value in dicmoi.items():
for keys in dic1.keys():
if dicmoi[keys]==value:
dictA.pop(keys)
if len(dictA)==1:
return dictA
dictA.update({key: value})
return dictA
k=input().split()
v=input().split()
if len(k)!=len(v):
print("Vui long nhap so luong key va value bang nhau!")
else:
dictA=dict(zip(k,v))
print(ketqua(dictA))