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

Ocena prostego skryptu PHP

Object Storage Arubacloud
0 głosów
169 wizyt
pytanie zadane 3 lipca 2018 w PHP przez chmod96 Obywatel (1,380 p.)

Cześć, napisałem skrypt, który w założeniu jest dość prosty. Mianowicie sprawdza czy dane słowo z tablicy da się utworzyć z podanych liter w drugiej tablicy. Wszystko działa okej, jednak ciekawi mnie wasza ocena i ewentualne inne lub inne lepsze pomysły na rozwiązanie tej zagwozdki.

Mój kod:

<?php

function test($words, $letters)
{
    // Variable that stores the results
    $results = array();

    // Get word by word from array
    foreach($words as $word)
    {
        
        // A temporary variable holding letters
        $temp = null;
        
        for($i = 0; $i < strlen($word); $i++)
        {
            // Get letter by letter from array
            foreach($letters as $letter)
            {
                // Checking if the letter from the word is like in the array
                if($letter == $word[$i])
                {
                    $temp = $temp . $word[$i];
                }
            }
        }

        if($word == $temp)
        {
            array_push($results, $temp);
        }
    }
    
    // Return the matching words in the array
    return $results;
}

// Data
$words = array("banan", "zebra", "kotwica", "pierogi", "warszawa");
$letters = array('b', 'w', 'e', 'r', 'd', 'm', 'z', 'a', 's', 'c', 'n');

// Run...
print_r(test($words, $letters));


?>

z góry dzięki za pomoc i ocenę.

komentarz 3 lipca 2018 przez Tomek Sochacki Ekspert (227,510 p.)
a czy skrypt uwzględnia możliwość wykonania słowa "banan" z liter "b,A,n" czyli czy wielkość liter musi mieć znaczenie? Może warto nie uwzględniać wielkości liter i literę "A" traktować jako poprawną do wykonania słowa "banan"?
komentarz 3 lipca 2018 przez chmod96 Obywatel (1,380 p.)
No tak masz rację, można to wprowadzić. Jednak teraz chodzi mi o ocenę algorytmu sprawdzającego, a inne przypadki  później będę kodził
komentarz 3 lipca 2018 przez chmod96 Obywatel (1,380 p.)

@Tomek Sochacki,

                // Checking if the letter from the word is like in the array
                if(strtolower($letter) === strtolower($word[$i]))
                {
                    $temp = $temp . $word[$i];
                }

To w sumie rozwiązuje problem :D

1
komentarz 3 lipca 2018 przez Tomek Sochacki Ekspert (227,510 p.)
nom... tylko tak się zastanawiam czy nie lepsze byłoby na samym początku zamienienie wszystkich liter na małe, osobiście staram się w instrukcjach warunkowych robić możliwie jak najprostsze porównania bez dodatkowych funkcji, ale też nie jest to jakaś sztywna reguła, to tylko taka sugestia, można by pobadać wydajność obu rozwiązań.
komentarz 3 lipca 2018 przez chmod96 Obywatel (1,380 p.)
była by to jakaś myśl, jednak jak szukałem na szybko takiego rozwiązania na stackoverflow i nie ma nic szybkiego na przekonwertowanie całego array na raz. na razie to rozwiązaneie się sprawdza więc nie ruszam :)
1
komentarz 3 lipca 2018 przez Tomek Sochacki Ekspert (227,510 p.)

nie ma nic szybkiego na przekonwertowanie całego array na raz

ja bym to zrobił array_map.

1 odpowiedź

+2 głosów
odpowiedź 3 lipca 2018 przez Mariusz08 Maniak (62,300 p.)
$results = array();

Możesz użyć skróconego zapisu tablicy []

function test($words, $letters)

Możesz określić typ argumentu oraz typ zwracanej wartości

if($word == $temp)

Można użyć ===

$words = array("banan", "zebra", "kotwica", "pierogi", "warszawa");

+ za pierogi wink

Poza tym można zrobić oddzielną klasę na tego typu sprawdzanie oraz przestrzeganie standardu PSR-2.

 

komentarz 3 lipca 2018 przez chmod96 Obywatel (1,380 p.)
Dzięki za odpowiedź, celne uwagi już je wprowadziłem jednak może rozwiniesz ostatni punkt.
komentarz 3 lipca 2018 przez Mariusz08 Maniak (62,300 p.)
Całą funkcję test zamieniłbym na jakąś klasę walidującą (OOP i te sprawy). A co do drugiego - przestrzeganie standardu PSR-2 który już w zasadzie jest standardem w większości firm. https://www.php-fig.org/psr/psr-2/

Podobne pytania

0 głosów
0 odpowiedzi 459 wizyt
pytanie zadane 18 września 2021 w C# przez johnreese234 Nowicjusz (120 p.)
0 głosów
1 odpowiedź 157 wizyt
pytanie zadane 26 lipca 2019 w C# przez KriX89 Nowicjusz (200 p.)
0 głosów
1 odpowiedź 271 wizyt
pytanie zadane 18 lutego 2019 w C i C++ przez Hiskiel Pasjonat (22,830 p.)

92,626 zapytań

141,486 odpowiedzi

319,844 komentarzy

62,009 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...