• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Funkcja przyjmująca liczbę większą od 0, zwracająca tablicę zawierającą wszystkie dzielniki podanej liczby

Aruba Cloud - Virtual Private Server VPS
0 głosów
1,879 wizyt
pytanie zadane 13 lutego 2017 w JavaScript przez svyatogor92 Użytkownik (670 p.)
zamknięte 13 lutego 2017 przez ScriptyChris

Witam, mam polecenie, z którym zupełnie nie wiem jak sobie poradzić:
Napisz funkcję factors, która ma przyjmować tylko jeden argument – liczbę, która musi być większa od 0. Funkcja ta ma zwracać tablicę zawierającą wszystkie dzielniki podanej liczby (w kolejności malejącej). Jeżeli liczba jest mniejsza lub równa 0, to funkcja ma zwracać pustą tablicę.
 

pomożecie to zrozumieć?
Nie wrzucam, żadnego kodu, ponieważ oprócz wypisania funkcji nie wiem nawet jak zacząć ;/

komentarz zamknięcia: Regulamin punkt II.2.G

1 odpowiedź

+1 głos
odpowiedź 13 lutego 2017 przez surfeliza Stary wyjadacz (11,260 p.)
var factors = function(nr){ //definicja funkcji
	var table = []; //definicja tablicy
	if(nr<=0) return table; //zwraca pustą tablice jeżeli nr <=0
	else { //w innym przypadku sprawdza dzielniki
  		for(var i=1;i<=nr;i++){ //petla od 1 do nr podanego przez uzytkownika
			if(nr%i === 0) table.unshift(i); //jeżeli reszta z dzielenia =0 to dodaj element do tablicy na sam poczatek
		}
   		return table; //zwroc tablice
	}
}

var test = factors(10);
alert(test);

 

1
komentarz 13 lutego 2017 przez Tomek Sochacki Ekspert (227,490 p.)
Rozwiązanie z unshift jest ok, ale należy zdawać sobie sprawę z mniejszej wydajności niż przy stosowaniu metody push z końcowym zastosowaniem reverse.

W ten sposób zmianę indeksów robimy tylko raz, natomiast w Twoim rozwiązaniu po każdym wywołaniu metody unshift następuje przenumerowanie tablicy.

Przy małych tablicach problem wydajności nie będzie istotny dlatego mój komentarz jest raczej taką mniej znaczącą dygresją, o o której warto pamiętać gdyby przyszło komuś tworzyć jakieś bardziej złożone algorytmy obliczeniowe.

93,327 zapytań

142,323 odpowiedzi

322,395 komentarzy

62,656 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...