Считайте максимальные стабильные сегментыJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Считайте максимальные стабильные сегменты

Сообщение Anonymous »

Заявление проблемы:
Склад управляет линейкой контейнеров, подготовленной для отгрузки. Каждый контейнер имеет указанную массу, указанную в списке массового списка, где массовый список представляет массу 𝑖 -й контейнера в составе. Например, учитывая массы [3, 6, 3], достоверные сегменты включают [3], [6], [3, 6], [6, 3] и [3, 6, 3] - но не [3, 3], поскольку контейнеры не являются смежными. < /P>
сегмент считается стабильным, если конечный контейнер не имеет максимального массы среди всех контейнеров, которые заставляют. Например:
[3, 9, 4, 7] стабильна (последняя масса 7, но максимум - 9).
[4, 7, 2, 7] не является стабильной (последняя масса - 7, что равняется максимуму). /> Каждый контейнер является частью ровно одного сегмента. < /p>
Каждый сегмент использует постоянную часть списка. = [1, 2, 3, 2, 6, 3]
одно действительное разделение: [1, 2, 3, 2] и [6, 3] < /p>
Оба являются стабильными сегментами. /> ограничения: < /strong> < /p>
2≤n≤10^5
1≤massList≤10^9
< /code>
Я использовал жадный подход для решения этого: < /p>
Мы делаем один проход через список и поддерживаем: < /p>
max: максимальная масса, наблюдаемая до сих пор в текущем сегменте.import java.util.*;

class ContainerPlanner {
public static int getMaxStableSegments(List massList) {
int n = massList.size();
int max = 0;
int stableCount = 0;

for (int i = 0; i < n; i++) {
int m = massList.get(i);
max = Math.max(m, max);
if (m < max && max > 0) {
stableCount++;
max = 0;
}
}

return stableCount;
}

public static void main(String[] args) {
System.out.println(getMaxStableSegments(Arrays.asList(1, 2, 3, 2, 6, 3))); // Output: 2
System.out.println(getMaxStableSegments(Arrays.asList(8, 5, 4, 7, 2))); // Output: 2
System.out.println(getMaxStableSegments(Arrays.asList(4, 3, 6, 5, 3, 4, 7, 1))); // Output: 3
System.out.println(getMaxStableSegments(Arrays.asList(
10, 5, 6, 4, 7, 6, 4, 2, 7, 1, 4, 6, 3, 4, 5, 1, 7, 5, 4, 6, 7, 8, 4, 6, 1, 9, 9
))); // Output: 1
}
}
< /code>
Я добавил некоторые тестовые случаи в основном методе, из 4 тестовых случаев 1 Тестовый экземпляр. Сбой < /p>
Ожидаемый выход - 1, но мое решение возвращает 10 для тестового примера < /p>
getMaxStableSegments(Arrays.asList(
10, 5, 6, 4, 7, 6, 4, 2, 7, 1, 4, 6, 3, 4, 5, 1, 7, 5, 4, 6, 7, 8, 4, 6, 1, 9, 9
)); // Output: 1
< /code>
Мой текущий жадный подход неверен, потому что он не может обрабатывать краевые случаи, когда невозможно разделить все массы на действительные стабильные сегменты. В результате это возвращающиеся значения, такие как 10 вместо правильного ответа, например, 1.>

Подробнее здесь: https://stackoverflow.com/questions/796 ... e-segments
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Считайте максимальные стабильные сегменты
    Anonymous » » в форуме JAVA
    0 Ответы
    1 Просмотры
    Последнее сообщение Anonymous
  • Считайте максимальные стабильные сегменты
    Anonymous » » в форуме JAVA
    0 Ответы
    0 Просмотры
    Последнее сообщение Anonymous
  • Максимально стабильные сегменты cout
    Anonymous » » в форуме JAVA
    0 Ответы
    1 Просмотры
    Последнее сообщение Anonymous
  • Максимально стабильные сегменты cout
    Anonymous » » в форуме JAVA
    0 Ответы
    2 Просмотры
    Последнее сообщение Anonymous
  • Максимально стабильные сегменты cout
    Anonymous » » в форуме JAVA
    0 Ответы
    1 Просмотры
    Последнее сообщение Anonymous

Вернуться в «JAVA»