Nước lạnh

Xem dạng PDF

Gửi bài giải


Điểm: 0,10 (OI)
Giới hạn thời gian: 1.0s
Giới hạn bộ nhớ: 512M
Input: stdin
Output: stdout

Nguồn bài:
USACO US-Open 2008 - Bảng Ðồng
Dạng bài
Ngôn ngữ cho phép
C, C++, Go, Java, Kotlin, Pascal, PyPy, Python, Rust, Scratch

Mùa hè oi ả ở Wisconsin đã khiến cho lũ bò phải đi tìm nước để làm dịu đi cơn khát. Các đường ống dẫn nước của nông dân John đã dẫn nước lạnh vào ~1~ tập ~N~ ~(3 \le N \le 99999~; ~N~ lẻ) nhánh (đánh số từ ~1~ ...~N)~ từ một cái bơm đặt ở chuồng bò.

Khi nước lạnh chảy qua các ống, sức nóng mùa hè sẽ làm nước ấm lên. Bessie muốn tìm chỗ có nước lạnh nhất để cô bò có thể tận hưởng mùa hè một cách thoải mái nhất.

Bessie đã vẽ sơ đồ toàn bộ các nhánh ống nước và nhận ra rằng nó là một đồ thị dạng cây với gốc là chuồng bò và ở các điểm nút ống thì có chính xác ~2~ nhánh con đi ra từ nút đó. Một điều ngạc nhiên là các nhánh ống này đều có độ dài là ~1~.

Cho bản đồ các ống nước, hãy cho biết khoảng cách từ chuồng bò tới tất cả các nút ống và ở các phần cuối đường ống.

"Phần cuối" của một đường ống, có thể là đi vào một nút ống hoặc là bị bịt, được gọi theo số thứ tự của đường ống. Bản đồ có ~C~ ~(1 \le C \le N)~ nút ống, được mô tả bằng ~3~ số nguyên: là "phần cuối" của ống ~E_i~ ~(1 \le~ ~E_i~ ~\le N)~ và ~2~ ống nhánh đi ra từ đó là ~B1_i~ và ~B2_i~ ~(2 \le~ ~B1_i~ ~\le N~; ~2 \le~ ~B2_i~ ~\le N)~. Đường ống số ~1~ nối với chuồng bò; khoảng cách từ phần cuối của đường ống này tới chuồng bò là ~1~.

Input

  • Dòng ~1~: ~2~ số nguyên cách nhau bởi dấu cách: ~N~ và ~C~
  • Dòng ~2~ ...~C+1~: Dòng ~i+1~ mô tả nút ống ~i~ với ba Số nguyên cách nhau bởi dấu cách: ~E_i~, ~B1_i~, và ~B2_i~

Output

  • Dòng ~1~ ...~N~: Dòng ~i~ chứa ~1~ số nguyên là khoảng cách từ chuồng tới "phần cuối" của ống thứ ~i~.

Sample Input

5 2
3 5 4
1 2 3

Sample Output

1
2
2
3
3

Note

Dữ liệu ở trên mô tả bản đồ ống nước sau:

+--------------+
|    Chuồng    |
+--------------+
       | 1
       *
    2 / \ 3
         *
      4 / \ 5

Giải thích: Ống ~1~ luôn cách chuồng ~1~ đoạn là ~1~. Ống ~2~ và ~3~ nối với ống ~1~ nên khoảng cách sẽ là ~2~. Ống ~4~ và ~5~ nối với ống ~3~ nên khoảng cách sẽ là ~3~.


Bình luận

Hãy đọc nội quy trước khi bình luận.



  • -3
    chithien19112008  đã bình luận lúc 23, Tháng 2, 2024, 13:47

    bai kho qua


  • -9
    mai_14112006  đã bình luận lúc 28, Tháng 9, 2023, 2:06

    Bình luận này đã bị ẩn vì có quá nhiều phản ứng tiêu cực. Nhấn để xem.