Trả về dict kết quả đã sắp xếp theo giá trị value tăng dần. (Tham số là 1 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 07:14 30-08-2021 147 lượt xem 0 bình luận
Tác giả/Dịch giả: TrongPhuCBL49 K9
Học nhanh

Danh sách bài học

Trả về dict kết quả đã sắp xếp theo giá trị value tăng dần. (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
  • Xử lý ngoại lệ (Exception Handling)
  • Các phương thức xử lý Dict trong Python:
    • Dict Constructor
    • items()

Đị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 là các số nguyên. 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ị value tăng dần
  • Lưu ý:
  • Nếu value 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:
Vui long nhap key la so nguyen!
  • Output 1:
{'mot': 1, 'ba': 3, 'nam': 5, 'hai': 2, 'bon': 4}
{'mot': 1, 'hai': 2, 'ba': 3, 'bon': 4, 'nam': 5}

  • Input 2:
{'mot': 1, 'ba': 3, 'nam': 5, 'hai': 2, 'bon': 4}
{'mot': 1, 'hai': 2, 'ba': 3, 'bon': 4, 'nam': 5}
  • Output 2:
{'nam': 5, 'am1': -1, 'hai': 2, 'khong': 0, 'bon': 4}
{'am1': -1, 'khong': 0, 'hai': 2, 'bon': 4, 'nam': 5}

  • Input 3:
Kteam 2021 free education
1 hai ba 4.5
  • Output 3:
Vui long nhap key la so nguyen!

  • Input 4:


  • Output 4:
{}
{}

  • Input 5:
mot hai
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.5).
  • Định nghĩa hàm sort_dict_by_value với tham số truyền vào là dict:
    • Sử dụng phương thức items() để lấy danh sách các tuple (key, value)
    • Sử dụng hàm sorted() kết hợp với tham số key=lambda item: item[1] (Có thể hiểu là sắp xếp các phần tử theo giá trị phần tử thứ 1 tăng dần của mỗi tuple) để có được danh sách các item của dict đã được sắp xếp tăng dần theo value.
    • Sử dụng Dict Constructor để tạo dict từ list items đã sắp xếp phía trê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_value 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

def nhap_dict():
    listKey = input().split()
    try:
        listValue = list(map(int, input().split()))
    except:
        print("Vui long nhap value la so nguyen!")
        return None

    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 sort_dict_by_value(dictA):
    listItem = dictA.items()
    listItemSorted = sorted(listItem, key=lambda item: item[1])
    dictKetQua = dict(listItemSorted)
    return dictKetQua

dictA = nhap_dict()

if dictA is not None:
    print(dictA)
    dictKetQua = sort_dict_by_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Ả ĐÃ SẮP XẾP THEO GIÁ TRỊ VALUE 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 VIẾT HÀM TRẢ VỀ CHUỖI KẾT QUẢ SAU KHI ĐÃ THAY THẾ CÁC TỪ CÓ KEY TRONG DICT BẰNG VALUE TƯƠNG ỨNG. (THAM SỐ LÀ 1 CHUỖI & 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

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ả

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
Không có video.