В парке находятся $$$n$$$ деревьев, пронумерованных от $$$1$$$ до $$$n$$$. Изначальная высота $$$i$$$-го дерева равна $$$h_i$$$.
Вы хотите полить эти деревья таким образом, чтобы они все выросли до одинаковой высоты.
Процесс полива происходит следующим образом. Вы начинаете поливать деревья в день $$$1$$$. В течение $$$j$$$-го дня вы можете:
Заметьте, что вы не можете поливать больше одного дерева в день.
Ваша задача — найти минимальное количество дней, необходимое для того, чтобы все деревья выросли до одинаковой высоты.
Вам необходимо ответить на $$$t$$$ независимых наборов тестовых данных.
Первая строка входных данных содержит одно целое число $$$t$$$ ($$$1 \le t \le 2 \cdot 10^4$$$) — количество наборов тестовых данных.
Первая строка набора тестовых данных содержит одно целое число $$$n$$$ ($$$1 \le n \le 3 \cdot 10^5$$$) — количество деревьев.
Вторая строка набора тестовых данных содержит $$$n$$$ целых чисел $$$h_1, h_2, \ldots, h_n$$$ ($$$1 \le h_i \le 10^9$$$), где $$$h_i$$$ равно высоте $$$i$$$-го дерева.
Гарантируется, что сумма $$$n$$$ по всем наборам тестовых данных не превосходит $$$3 \cdot 10^5$$$ ($$$\sum n \le 3 \cdot 10^5$$$).
Для каждого набора тестовых данных выведите одно целое число — минимальное количество дней, необходимое для того, чтобы все деревья выросли до одинаковой высоты.
331 2 454 4 3 5 572 5 4 8 3 7 4
4 3 16
Рассмотрим первый набор тестовых данных примера. Изначальное состояние деревьев выглядит как $$$[1, 2, 4]$$$.
Таким образом, ответ равен $$$4$$$.
Название |
---|