Tương truyền rằng, Hàn Tín (danh tướng đời Hán) khi kiểm điểm quân số thường làm như sau. Ông cho lính xếp thành hàng \(3\), sau đó hàng \(5\), rồi hàng \(7\). Mỗi lần như vậy, quân lính báo cho Hàn Tín số người ở hàng cuối cùng (có thể không đủ \(3, 5, 7\)). Từ đó ông suy ra số quân chính xác. Thực chất Hàn Tín đã giải một hệ đồng dư tuyến tính theo modun \(3, 5, 7\). Bài toán trên nổi tiếng dưới tên gọi “Hàn Tín điểm binh” và thuật toán mà ông dùng dựa trên một trong những định lý nổi tiếng nhất của toán học “Định lý Trung Quốc về số dư”.
Cho trước số nguyên dương \(n\) và \(n\) số nguyên \(a_1, a_2, …, a_n\) và \(n\) số nguyên \(m_1, m_2, …, m_n\), trong đó \(m_1, m_2, …, m_n\) là các số nguyên tố cùng nhau từng đôi một. Nhiệm vụ của bạn là tìm nghiệm nguyên không âm nhỏ nhất \(x\) của hệ phương trình đồng dư tuyến tính sau:
\(\left\{\begin{matrix} x \equiv a_1 & \pmod{m_1} \\x \equiv a_2 & \pmod{m_2} \\... \\x \equiv a_n & \pmod{m_n} \end{matrix}\right.\)
Input
- Dòng đầu tiên chứa số nguyên \(n\) (\(1 \leq n \leq 8\)).
- Dòng thứ \(i\) trong số \(n\) dòng tiếp theo chứa hai số nguyên \(a_i\) (\(-10^9 \leq a_i \leq 10^9\)) và \(m_i\) (\(2 \leq m_i \leq 100\)).
Dữ liệu vào đảm bảo \(m_1, m_2, …, m_n\) là các số nguyên tố cùng nhau từng đôi một.
Output
- Ghi ra một số nguyên là nghiệm nguyên không âm nhỏ nhất \(x\) tìm được.
Example
Test 1
Input
3
2 3
3 5
2 7
Output
23
Test 2
Input
1
-99 100
Output
1
Bình luận