Task/Quest sắp xếp như thế nào

  • Ở tài liệu tích hợp GSM SDK cho Task Quest Log có mô tả:

  • Hệ thống sẽ nhận dữ liệu từ game và sắp sếp theo ưu tiên sau:

    • Sắp sếp theo taskPriority theo từ thấp đến cao.

    • Nếu cùng 1 giá trị taskPriority thì sẽ sắp sếp taskName theo nguyên lý Alpha B.

Ví dụ: Ta có bảng dữ liệu sau

  • Các task: 0_1_1, 10_1_1, 10_1_2, 10_1_3 cùng 1 taskPriority=0 nên được sắp sếp lên đầu.

  • Mặc dù, 10_1_1 nhìn có vẻ lớn hơn 1_3_1, nhưng do taskPriority được ưu tiên sắp sếp trước.

  • Trong cùng 1 priority=0, thì sắp sếp theo kiểu so sánh chuỗi như sau:

Nguyên lý sắp xếp chuỗi trong lập trình thường dựa trên so sánh giữa các ký tự trong chuỗi, từ trái sang phải. Cụ thể, nó tuân theo quy tắc:

  1. So sánh từng ký tự:

    • Bắt đầu từ ký tự đầu tiên của mỗi chuỗi, so sánh giá trị ASCII hoặc Unicode của chúng.

    • Nếu ký tự tại vị trí hiện tại của chuỗi thứ nhất lớn hơn ký tự tương ứng của chuỗi thứ hai, thì chuỗi thứ nhất đứng trước trong thứ tự sắp xếp.

    • Nếu ký tự tại vị trí hiện tại của chuỗi thứ nhất nhỏ hơn ký tự tương ứng của chuỗi thứ hai, thì chuỗi thứ nhất đứng sau trong thứ tự sắp xếp.

    • Nếu ký tự bằng nhau, di chuyển đến ký tự tiếp theo và lặp lại quy trình so sánh.

  2. Khi gặp ký tự khác nhau:

    • Nếu một trong hai chuỗi kết thúc, chuỗi kết thúc sớm hơn sẽ đứng trước trong thứ tự sắp xếp.

    • Nếu cả hai chuỗi đều kết thúc, chúng được coi là bằng nhau.

  3. Áp dụng lặp lại cho tất cả các ký tự:

    • Quy trình trên được lặp lại cho tất cả các ký tự trong chuỗi.

Ví dụ:

  • "abc" đứng trước "def" vì 'a' < 'd'.

  • "apple" đứng trước "banana" vì 'a' < 'b'.

  • "abc" đứng trước "abcd" vì "abc" là một phần của "abcd".

Nguyên lý này thường được áp dụng trong các thuật toán sắp xếp như Bubble Sort, Insertion Sort, Selection Sort, và cả trong các hàm sắp xếp của nhiều ngôn ngữ lập trình.

Gợi ý cách đặt task name

  • Nên đặt taskname kiểu: [Thứ tự]TaskName. Ví dụ: 0001_task1, 0002_task2 ...

Last updated