Załóżmy, że odczytujemy ciąg liczb, jeden po drugim. Jak znaleźć najmniejszy element za pomocą pamięci komórkowej oraz w czasie liniowym ( ). Myślę, że powinniśmy zapisać pierwsze wyrażeń w sekwencji, a kiedy otrzymamy -ty termin, usuń go, który z pewnością nie może być -tym najmniejszym elementem, a następnie zapisz -ty termin. Powinniśmy więc mieć wskaźnik, który pokazuje ten bezużyteczny termin na każdym etapie, a wskaźnik ten powinien być aktualizowany na każdym kroku szybko. Zacząłem od „max”; ale nie można szybko zaktualizować; Oznacza to, że jeśli weźmiemy pod uwagę max, to przy pierwszym usuwaniu pomijamy maksimum i powinniśmy szukać maksimum w i jego przyczynie czas, że nie jest on liniowy. Może powinniśmy bardziej inteligentnie zapisać pierwsze warunków sekwencji.
Jak rozwiązać ten problem?