Trả về dict kết quả đã sắp xếp theo giá trị key tăng dần. (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ả đã sắp xếp theo giá trị key tăng dần. (Tham số là 1 dict)
Nội dung bài viết Học nhanh
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
- Xử lý ngoại lệ (Exception Handling)
- Các phương thức xử lý Dict trong
Python:
- Dict Constructor
- keys()
Đị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 là các số nguyên. 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 hai dòng:
- Dòng đầu tiên hiển thị dict được nhập từ bàn phím
- Dòng thứ hai hiển thị dict đã được sắp xếp theo giá trị key tăng dần
Lưu ý:
- Nếu key không phải là số nguyên thì xuất thông báo: Vui long nhap key la so nguyen!
- 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:
- Output 1:
- Input 2:
- Output 2:
- Input 3:
- Output 3:
- Input 4:
- Output 4:
- Input 5:
- Output 5:
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.5).
- Định nghĩa hàm sort_dict_by_key với tham số truyền vào là dict:
- Sử dụng phương thức keys() để lấy list các key
- Sắp xếp list key theo thứ tự tăng dần
- Duyệt qua list key và khởi tạo dict mới theo thứ tự key tăng dần
- 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 sort_dict_by_key và truyền vào tham số cần thiết.
- Sử dụng hàm print() để hiển thị kết quả ra màn hình theo định dạng đầu ra
Code mẫu
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Ả ĐÃ SẮP XẾP THEO GIÁ TRỊ KEY TĂNG DẦN. (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 TRẢ VỀ DICT KẾT QUẢ ĐÃ SẮP XẾP THEO GIÁ TRỊ VALUE TĂNG DẦN. (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ả đã sắp xếp theo giá trị key tăng dần. (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.
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 func(dic):
sorted_dic = dict(sorted(dic.items()))
return "{}\n{}".format(dic,sorted_dic)
while True:
try:
lstkeys = list(map(int,input("Nhập danh sách keys: ").split()))
lstvalues = input("Nhập danh sách values: ").split()
dic = dict(zip(lstkeys,lstvalues))
if len(lstkeys) != len(lstvalues):
print("Vui lòng nhập số lượng key và value bằng nhau!")
else:
print(func(dic))
except ValueError:
print("Vui lòng nhập key là số nguyên!")
def nhapgiatri():
key=input().split()
value=input().split()
try:
key1=list(map(int,key))
except:
print("Vui long nhap key la so nguyen!")
return None
if len(key)!=len(value):
print("Vui long nhap so luong key va value bang nhau!")
return None
return dict(zip(key1,value))
def Ketqua(dictA):
print(dictA)
listA=list(dictA.keys())
listA.sort(reverse=True)
return {i: dictA[i] for i in listA}
dictA=nhapgiatri()
if dictA is not None:
print(Ketqua(dictA))