Najneskorší termín odovzdania: 18.4.2017 (utorok) o 21:00
Odovzdávané súbory: Rebus.java
Doplňujúce požiadavky:
Igor našiel v jednom časopise takýto matematický rébus:
Vložte medzi niektoré cifry čísla 123456789
znamienko +
alebo -
tak, aby výsledok vytvoreného výrazu bol 100.
Igor ako skúsený riešiteľ rébusov rýchlo našiel riešenie: 100 = 123 - 45 - 67 + 89
. Vtedy si ale Igor položil ďalšiu otázku. Koľko rôznych riešení má táto úloha?
Vytvorte pre Igora program, ktorý bude zisťovať, počet rôznych riešení rébusu. Program bude čítať vstup z textového súboru s názvom rebusy.txt
:
123456789 100 123456789 99 12344321 325 111222333 22
Formát súboru je taký, že každý riadok predstavuje jeden rébus ako dve medzerou oddelené čísla. Prvé číslo (nanajvýš 15-ciferné) predstavuje postupnosť cifier a druhé číslo predstavuje požadovaný výsledok po vložení znamienok +
a -
do tejto postupnosti.
Program nech vytvorí výstupný súbor PoctyRieseni.txt
, ktorý bude obsahovať pre každý rébus celkový počet jeho riešení - pre i-ty rébus bude počet jeho riešení zapísaný v i-tom riadku.
11 17 3 60
Nedávno ma zaujala jedna časť TV show zo série Penn&Teller s názvom Úžasná Allison:
Nie, nezaujal ma trik, vďaka ktorému sa je možné "dozvedieť sa" myslené a neskôr napísané číslo, ale prezentácia tohto triku. Myslené číslo sa neodhalí ihneď, ale Allison toto číslo skryje do 16 čísel v tabuľke 4x4 (viac vo videu). Určite sa vám po prezretí videa v hlave vynoria otázky (ak nie, tak sa tak aspoň chvíľu tvárme):
Úloha: Analyzujte možnosti vyplnenia tabuľky v tomto triku. Ako rozumné sa zdá začať s vytvorením programu, ktorý pre zadané číslo X nájde jedno (alebo viaceré?) vyplnenia tabuľky kladnými nenulovými číslami, že príslušné štvorice čísel majú súčet presne X. Uvažujeme tieto štvorice:
Je to menej štvoríc a aj iné štvorice ako bolo v show - kvôli zjednodušeniu. Pri iných videách sa dá vidieť, že Allison tiež od niektorých štvoríc upustila: https://www.youtube.com/channel/UCUSEn9drforS2TNfeSK5RVA/videos
Odovzdajte:
Tabulka.java
s triedou Tabulka
:
Tabulka
implementujte čo najefektívnejšiu metódu vytvorPreCislo
, ktorá pre zadané celé číslo medzi 25 a 99 vráti 2D pole s rozmermi 4x4 vyplnené kladnými nenulovými celými číslami pričom:
x
a
null
.
Tabulka
je kontrolovaná evaluátorom. Pri efektívnej implementácii môžete využiť výsledky analýzy (ak analýza nejaké užitočné vlastnosti, použite ich pri implementácii tejto triedy).
Riešenia, ktoré nebudú obsahovať všetky 3 požadované časti, nebudú hodnotené (ak "akékoľvek podporné zdrojové kódy" tvorí len trieda Tabulka
, nemusíte v rámci tejto druhej časti odovzdávať nič ďalšie).