Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP] Pętla for oraz if
hunter777
post
Post #1





Grupa: Zarejestrowani
Postów: 40
Pomógł: 0
Dołączył: 8.02.2017

Ostrzeżenie: (0%)
-----


mam takie zadanko,
sprawdź tablicę znaków np [1,1,3,4] i jeśli można za pomocą zabrania tylko jednego elementu sprawić by ciąg liczb był rosnący zwróć true.

zrobiłem to tak

  1. function almostIncreasingSequence($sequence) {
  2. $t = $sequence;
  3. $j = count($sequence);
  4.  
  5.  
  6.  
  7. for ($i=0; $i<$j; $i++) {
  8. $a[$i] = $t[$i];
  9. $b[$i] = $t[$i-1];
  10.  
  11. if ($b > $a) {
  12. $c = $c++;
  13.  
  14. return $c; }
  15. }
  16.  
  17. }
  18. if ($c > 2) {
  19.  
  20. return false;
  21.  
  22. } else {
  23.  
  24. return true;
  25. }


ale to niestety nie działa, wychodzi mi z pętli po jednym elemencie...
coś robię nie tak..

ja to wymyśliłem tak, sprawdź każdy element w tablicy i porównaj każdy kolejny z poprzednim i jeśli poprzedni jest większy od następnego to zwiększ licznik, jeśli licznik będzie większy niż 1 tzn, że mam więcej niż jedną liczbę...

poproszę o jakieś sugestie a nie gotowe rozwiązanie, z góry dziękuję
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
hunter777
post
Post #2





Grupa: Zarejestrowani
Postów: 40
Pomógł: 0
Dołączył: 8.02.2017

Ostrzeżenie: (0%)
-----


posortowanie raczej odpada moim zdaniem... nic nie wnosi albo tego nie rozumiem...

odpowiedz kreatiffa także jest błędna ponieważ wysypuje się na tablicy - [1, 3, 2, 1]


zrobiłem coś takiego, sprawdza czy tablica nie ma duplikatów i porównuje je ale... znowu jest problem ponieważ gdy mamy tablice [1,3,2] to spełnia wszystkie te warunki a odpowiedz jest zła ponieważ jeśli zabierzemy 2 lub 3 to ciąg będzie rosnący... a on daje false, ponieważ nie ma duplikatów i raz znajduje większy poprzdeni wiersz... niby to proste ale nie za proste dla mnie...



  1. function almostIncreasingSequence($sequence) {
  2. $t = $sequence;
  3. $j = count($sequence);
  4.  
  5.  
  6.  
  7. for ($i=0; $i<$j-1; $i++) {
  8. $a[$i] = $t[$i];
  9. $b[$i] = $t[$i+1];
  10.  
  11. $c[$i] = ($a[$i] >= $b[$i]);
  12. }
  13. $e = count(array_filter($c));
  14. $f = count(array_unique($t));
  15. $g = $f == $j;
  16. if ($e >= 1 OR $g = true) {
  17. return false;
  18. } else {
  19. return true;
  20. }
  21. }


Ten post edytował hunter777 6.11.2017, 16:12:10
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 17.10.2025 - 14:46