Czy zdałeś pytanie z algorytmu rozmowy kwalifikacyjnej? Uczenie się pytań dotyczących algorytmu zajmuje zbyt dużo czasu? Nie twój problem! Wcześniej żadna metoda uczenia się algorytmicznego nie mogła być tak prosta i skuteczna. Aby zostać mistrzem algorytmów, wystarczą tylko trzy kroki: Pierwszym krokiem jest przeczytanie pytania; Drugim krokiem jest odtworzenie animacji, zapoznanie się z napisami i zrozumienie pomysły i kody; Trzeci krok to przeczytanie, analiza i podsumowanie;
Stworzenie aplikacji do tworzenia diagramów animacji algorytmów wynika z osobistych doświadczeń wielu programistów, którzy często muszą przeglądać algorytmy przy każdej zmianie pracy. Proces ponownego przeglądania tych algorytmów zazwyczaj obejmuje przyjrzenie się różnym rozwiązaniom internetowym, z których wiele zawiera animowane wizualizacje lub schematy. Te formy reprezentacji są skuteczniejsze i szybsze do zrozumienia niż sam tekst. Uwidoczniły się jednak pewne ograniczenia istniejących zasobów, w tym brak interaktywności w animacjach, brak możliwości zmiany danych podczas nauki oraz wyzwania związane z dostępnością mobilną.
Zmotywowany chęcią ulepszenia nauki, programista zobowiązał się do stworzenia 70 różnych animacji w aplikacji. Głównym celem tej aplikacji jest służenie jako narzędzie edukacyjne, które pomaga użytkownikom w szybkim zrozumieniu koncepcji algorytmów i kodu. Chociaż aplikacja zapewnia wizualną i interaktywną naukę, nie pozwala użytkownikom na przesyłanie ani wykonywanie kodu; wpisanie kodu na komputerze pozostaje konieczne, aby móc się w pełni uczyć.
Organizując zawartość aplikacji, programista zdecydował się nie porządkować pytań algorytmicznych według numerów identyfikacyjnych LeetCode. Zamiast tego podzielili pytania na trzy główne kategorie: listy połączone, ciągi znaków, tablice i drzewa binarne; cofanie się, algorytmy zachłanne, programowanie dynamiczne oraz zasada „dziel i zwyciężaj”; wraz z wydzieloną sekcją do sortowania. Każda kategoria jest dodatkowo podzielona według stopnia trudności – łatwy, średni i trudny – umożliwiając użytkownikom skupienie się na określonych obszarach wiedzy sekwencyjnie, zachęcając jednocześnie do dokładnego poznania koncepcji teoretycznych.
Aplikacja odzwierciedla także dotychczasowe doświadczenia programisty, w szczególności wyzwania stojące przed algorytmami sortowania. Ponieważ sortowanie było początkowo postrzegane jako trudny temat, dla początkujących wyznaczono specjalną klasyfikację, aby ułatwić lepsze zrozumienie. To ustrukturyzowane podejście ma na celu pomóc użytkownikom w systematycznym poruszaniu się po złożonych tematach w sposób zgodny z tradycyjnymi ramami edukacyjnymi.
Aby poprawić interakcję między animacją a kodem, aplikacja zawiera kilka przemyślanych funkcji. Jednym z kluczowych aspektów jest funkcja podświetlania kodu, która synchronizuje animację z wykonaniem kodu poprzez podświetlanie każdej linii kodu w miarę postępu odpowiedniej animacji. Dodatkowo, aby uzupełnić elementy wizualne, dodano funkcję napisów, które zapewniają krótkie wyjaśnienia na każdym etapie animacji. Aplikacja zawiera także funkcję odtwarzania i resetowania każdego algorytmu, dzięki czemu użytkownicy mogą losowo wybierać przypadki testowe za pomocą przycisku resetowania, co jeszcze bardziej upraszcza proces uczenia się i zwiększa zaangażowanie użytkowników.
Dlaczego tworzysz aplikację do tworzenia diagramów animacji algorytmów ?
Jak wielu programistów, muszę przygotować dużo czasu na odświeżenie algorytmu za każdym razem, gdy zmieniam pracę. Bardzo dobrze, w trakcie rozwiązywania pytań musisz najpierw przeczytać rozwiązanie. Czytam też w Internecie wiele rozwiązań problemów od dużych facetów, a szczególnie lubię czytać analizy algorytmów za pomocą ruchomych obrazów lub schematów, co jest szybsze niż czytanie tekstu. W trakcie tego procesu wykryto również kilka problemów, takich jak: animacja nie jest interaktywna i nie można jej wstrzymać; dane są martwe i nie można ich zmienić; nie jest wygodnie uczyć się na telefonie komórkowym itp.
Na początku widziałem kilka dobrych animacji i miałem silną potrzebę, aby kilka razy zaimplementować je w aplikacji z natywnym kodem. Tym razem w końcu się zdecydowałem i zrobiłem 70 animacji za jednym razem.
Rozumiem, że pozycjonowanie tej aplikacji to narzędzie, które może nam pomóc szybko zrozumieć pomysły i kody algorytmów, wspomóc pamięć i poprawić efektywność uczenia się. Ale tutaj nie możesz przesłać, nie możesz wykonać kodu, a kod i tak trzeba wpisać na komputerze, żeby poczuć się lepiej.
Dlaczego nie jest on ułożony w kolejności leetcode liczba?
Obecnie pytania algorytmu są podzielone na trzy główne bloki:
- lista połączona, ciąg znaków, tablica, drzewo binarne;
- Wycofywanie się, zachłanność, programowanie dynamiczne, dziel i zwyciężaj;
- Sortuj i klasyfikuj osobno.
W każdej kategorii poziom trudności jest podzielony na łatwy, średni i trudny.
Najpierw oddzielnie klasyfikuj struktury danych i algorytmy i ucz się według punktów wiedzy. Na przykład możesz skoncentrować się na nauce binarnych struktur drzewnych lub algorytmów programowania dynamicznego, dzięki czemu trening skoncentrowanego nasycenia może pomóc poprawić efektywność uczenia się. Na pierwszym miejscu jest struktura danych, po niej następuje algorytm, który również jest ułożony w kolejności, w jakiej zdobywamy wiedzę teoretyczną.
Jeśli chodzi o algorytmy, obecnie wyróżnia się cztery ich typy: wycofywanie się, zachłanność, programowanie dynamiczne oraz dzielenie i -conquer.
Kiedy wiele lat temu uczyłem się struktur danych i algorytmów, po raz pierwszy zetknąłem się z różnymi algorytmami sortowania. Poczułem wtedy, że sortowanie jest zbyt trudne i zrobiło to na mnie ogromne wrażenie, dlatego stworzyłem osobną klasyfikację sortowania dla początkujących.
Myślałem o tym, jak połączyć animację z kodem i innymi zagadnieniami interaktywnymi
- W procesie samodzielnego uczenia się algorytmów często rozumiem idee, ale nie rozumiem kodów, a wiele kodów w objaśnieniach tekstowych nie ma komentarzy. Widzenie tego powoduje duży ból głowy. Dlatego też, myśląc o interakcji aplikacji, specjalnie zaprojektowano funkcję podświetlania kodu, co oznacza, że każda linia kodu będzie podświetlana w miarę postępu animacji. W ten sposób animacja jest wykonywana, kod jest podświetlany i wygląda fajnie.
- Chociaż animacja jest łatwa do zrozumienia, nadal wymaga krótkich objaśnień, dlatego funkcja „podtytuł” została zaprojektowana pod animacją. Za każdym razem, gdy wykonywany jest odpowiedni krok, zostanie wyświetlone odpowiednie wyjaśnienie.
- Odtwarzanie i resetowanie animacji, każda strona algorytmu ma funkcję odtwarzania, więc jak przygotować przypadki testowe? Aby uprościć koncepcję przypadków testowych, zaprojektowano przycisk „reset”, co oznacza, że przypadki testowe są losowe. Jeśli chcesz zmienić zestaw danych, po prostu kliknij reset.