Câu chuyện cổ tích về người cha và bó đũa nhắc nhở chúng ta rằng: có đoàn kết thì mới có sức mạnh.
Bạn có ~n~ bó đũa trên một hàng ngang, bó đũa thứ ~i~ có sức mạnh là ~a_i~. Tại mỗi bước, bạn có thể buộc hai bó đũa nằm cạnh nhau và có sức mạnh giống nhau để tạo thành một bó đũa có sức mạnh mới lớn hơn 1 đơn vị so với ban đầu. Bó đũa mới chiếm vị trí của hai bó đũa cũ, và thứ tự của các bó đũa được giữ nguyên.
Để thể hiện tinh thần đoàn kết ở mức cao nhất, bạn muốn lặp lại thao tác trên nhiều lần nhất có thể. Nói cách khác, bạn muốn số lượng bó đũa còn lại là tối thiểu.
Yêu cầu: Hãy viết chương trình tính số lượng bó đũa còn lại tối thiểu có thể đạt được.
**Dữ liệu: **
Kết quả: Ghi duy nhất một số nguyên là số bó đũa tối thiểu có thể đạt được.
Ví dụ:
Input 1
6
1 1 2 2 2 1
Output 1
2
Input 2
5
1 1 1 2 1
Output 2
3
**Ràng buộc: **
Code tích cực |
---|
Trong 24h |
|
Trong 7 ngày |
Trong 30 ngày |
Thống kê |
---|
AC/Sub: 97887/180710 Pascal: 17121 C++: 130348 Python: 33199 Lượt xem/tải tests: 37787 |