- Google Pixel topik
- Megjött a jubileumi Pixel széria
- Motorola Edge 40 - jó bőr
- Hivatalos a OnePlus 13 startdátuma
- Azonnali mobilos kérdések órája
- Mobil flották
- iPhone topik
- Samsung Galaxy S21 Ultra - vákuumcsomagolás
- Honor Magic V5 - méret a kamera mögött
- Műholdakkal is beszélgethet a Redmi Note 15 Pro+
Új hozzászólás Aktív témák
-
htc07
addikt
Sziasztok!
Igazából sosem tanították nekem a PHP-t, mindig csak google alapján hánytam össze amire épp szükségem volt, de most kifogott rajtam egy dolog, remélem tudtok segíteni, hol rontom el.
Ezt kellene kiszámolni:
Egy iskolába 1000 diák jár, és 1000 szekrény van a folyosón. Az igazgató az első napon megkéri az egyik tanulót, menjen ki a folyosóra, és nyissa ki az összes szekrényt. Ezután megkér egy másik tanulót, menjen, és minden második szekrényajtót csukjon be. Majd azt kéri egy harmadik tanulótól, hogy minden harmadik ajtót csukjon be, ha nyitva van, és nyisson ki, ha zárva. A negyedik gyerek minden negyedik ajtóhoz megy oda, és így tovább, lassan mind az ezer gyerek sorra kerül. A végén hány ajtó marad nyitva?
Ezt sikerült összedobálnom (1000 helyett 50-et használtam, hogy gyorsabban lefusson amíg rájövök mi a rossz).
<?php
$i=1; //hanyadik diak
$ajtoszam=$i; // 3: minden harmadik, 8: minden nyolcadik ajtó...
$hanydiak = 50; // hány diák, hány ciklus
$ajto=array_fill(1, $hanydiak, "1"); // 1: zart, 0: nyitott
function nyitzar($ajtoszam)
{
if($ajtoszam <= $hanydiak)
{
if($ajto[$ajtoszam] == "1")
{
$ajto[$ajtoszam] = "0";
}
else
{
$ajto[$ajtoszam] = "1";
}
$ajtoszam=$ajtoszam+$ajtoszam;
nyitzar($ajtoszam);
}
}
function hanyadik($i)
{
if($i <= $hanydiak)
{
nyitzar($ajtoszam);
$i++;
hanyadik($i);
}
}
hanyadik($i);
$eredmeny = array_count_values($ajto);
echo $eredmeny['1']. " ajto marad nyitva";
?>Tuti hogy a function-nel rontok el valamit, az ismétlődő ciklusokkal sem volt sok dolgom eddig, meg így estére már elfáradt az agyam
A megoldást tudom, azt is hogy miért annyi, (ez google), de a kiszámolás megvalósítása lenne az érdekes számomra, nem az igazgató megkérdőjelezhető hóbortja.
Új hozzászólás Aktív témák
- HP ProLiant MicroServer N36L / N40L / N54L
- Kerékpárosok, bringások ide!
- Milyen alaplapot vegyek?
- Telekom otthoni szolgáltatások (TV, internet, telefon)
- Bittorrent topik
- Elektromos autók - motorok
- Audi, Cupra, Seat, Skoda, Volkswagen topik
- Energiaital topic
- Gitáros topic
- Calibre, az elektronikus könyvtár
- További aktív témák...
- Samsung Galaxy S25 128GB Kártyafüggetlen 1 év Garanciával
- Eladó szép állapotban levő Samsung S22 8/128GB / 12 hó jótállással
- DELL Precision 7730 i5-8400H Quadro P3200 32GB 1000GB FHD 17 1 év garancia
- BESZÁMÍTÁS! Microsoft XBOX Series X 1TB SSD fekete játékkonzol garanciával hibátlan működéssel
- Nintendo Switch V2
Állásajánlatok
Cég: FOTC
Város: Budapest