Đầu tiên ta cần tính thời gian qua cầu của mỗi người (khi đi một mình).
Có thể tính bằng tham lam như cách được sử dụng trong code ở trên hoặc
kết hợp quy hoạch động với deque để tìm min trên đoạn tịnh tiến.
Độ phức tạp khi tính là \(O(m)\) cho mỗi người, vì \(r\) chỉ dao động từ
1 đến 100 nên ta dùng một mảng phụ để cache giá trị đã tính lại.
Sau khi tính xong, gọi thời gian qua cầu của \(n\) người là \(A(n)\), ta
sắp xếp \(A\) tăng dần.
Gọi \(F(i)\) là thời gian ít nhất để những người từ 1 đến i qua cầu, ta có công thức:
\[F(1) = A(1) \\
F(2) = A(2) \\
F(i) = min
\begin{cases}
F(i-2) + A(1) + 2A(2) + A(i) & \quad (1)\\
F(i-1) + A(1) + A(i) & \quad (2)\\
\end{cases}\]
Trong trường hợp \((1)\), ta cho \(A(2)\) quay về, sau đó \(A(i)\) và
\(A(i-1)\) qua cầu, sau đó \(A(1)\) từ bên kia cầu quay về, \(A(1)\)
và \(A(2)\) cùng qua cầu.
Trong trường hợp \((2)\), \(A(1)\) quay về sau đó cùng \(A(i)\) qua cầu.