Danh bạ điện thoại


Submit solution

Points: 3
Time limit: 1.0s
Memory limit: 256M

Author:
Problem type
Allowed languages
Ada, Assembly, Awk, C, C++, C11, CLANG, CLANGX, Classical, COBOL, Coffee, CSC, D lang, DART, F95, FORTH, Fortrn, GAS32, GO, Haskell, Itercal, Java, kotlin, LEAN, LISP, LUA, MONOVB, Nasm, OCAML, Pascal, Perl, php, PIKE, prolog, Pypy, Python, Ruby 2, RUST, Scala, SCM, SED, SWIFT, TCL, TUR, V8JS, VB, ZIG

Bình có một danh bạ điện thoại dùng để lưu thông tin về các người bạn. Các số điện thoại trong danh bạ của Bình đều là số có 9 chữ số và không được bắt đầu bởi chữ số 0.

Với hệ điều hành mà Bình đang sử dụng, khi bấm tìm kiếm một số điện thoại nào đó trong danh bạ thì màn hình sẽ hiển thị ra tất cả các số điện thoại mà có các chữ số liên tiếp trùng với số được tìm kiếm. Ví dụ trong danh bạ của Bình có 3 số điện thoại là 100000007, 123456789, 100012345 thì:

Khi bấm 00 thì màn hình sẽ hiển thị ra 2 số là 100000007 và 100012345. Khi bấm 345 thì màn hình sẽ hiển thị ra 2 số là 123456789 và 100012345. Khi bấm 07 thì chỉ có 1 số điện thoại được hiển thị ra màn hình là 100000007 Biết thông tin về các số điện thoại trong danh bạ được lưu dưới dạng mảng các xâu arr, ứng với mỗi số điện thoại trong danh bạ, bạn hãy xác định xâu có độ dài ngắn nhất mà khi Bình tìm kiếm thì màn hình sẽ chỉ hiển thị đúng số điện thoại này. Nếu có nhiều hơn một xâu thỏa mãn thì lấy xâu có giá trị số nguyên nhỏ nhất.

Kết quả trả về sẽ là mảng các xâu tương ứng với mỗi số điện thoại.

Input

  • Dòng đầu chứa số nguyên n là số phần tử trong mảng arr. (1 <= \(n\) <= 500).
  • Dòng tiếp theo chứa n số điện điện, mỗi số điện thoại cách nhau bởi một khoảng trắng.
  • Lưu ý: Đầu vào luôn đảm bảo các số điện thoại trong danh bạ là khác nhau.

Output

  • Kết quả trả về trên 1 dòng là các xâu kết quả tương ứng với mỗi số điện thoại, mỗi xâu cách nhau một khoảng trắng.

Example

Input

3
100000007, 123456789, 100012345

Output

07 6 01

Giải thích:

  • Khi bấm "07" thì chỉ có số điện thoại thứ nhất hiện ra.
  • Lưu ý: Bạn cũng có thể bấm các số khác như "007", "10000", ... nhưng các số này không có độ dài nhỏ nhất.
  • Khi bấm "6" thì chỉ có số điện thoại thứ hai hiện ra.
  • Khi bấm "01" thì chỉ có số điện thoại thứ 3 hiện ra.

Input

2
101122334 230415555

Output

01 5

Lưu ý: với số điện thoại đầu tiên bạn có thể bấm "10", "11", "22", ... nhưng các số này đều có giá trị nguyên lớn hơn "01" nên kết quả của số đầu tiên sẽ là "01".


Comments


  • -1
    MinhDuc_CNTT1_K64  commented on Oct. 22, 2023, 10:21 a.m.

    cho em hỏi test case thứ 15 có trường hợp đặc biệt gì vậy ạ, e toàn sai test đó :<