From 356195ee77fdbebcca310e3a9250a61c4f117941 Mon Sep 17 00:00:00 2001
From: Aleksander Sadikov Za začetek se spomnimo, da vstavljamo v urejen seznam. Sprehodimo se po njem, dokler ne najdemo
+ustreznega mesta za novi element. Korak za korakom nov element primerjamo s trenutno glavo seznama v katerega vstavljamo. Glave bodo vedno
+večje, ker je originalni seznam urejen. Kar pomeni, da bo enkrat novi element manjši od trenutne glave, kajne? Če je nov element Operator Si pomislil na robni pogoj? Kaj je najbolj enostaven primer, ko je element v seznamu?
-Do katerega elementa najlažje prideš? Si pomislil na robni pogoj? To bo najbrž kar primer, ko (končno) vstaviš nov element v seznam.X
večji od trenutne glave H
, potem ga vstavimo nekam v rep -- za to bo,
+kot vedno, poskrbela rekurzija, kajne? Sicer pa smo že našli ustrezno mesto in ga vstavimo sedaj pred trenutno
+glavo H
! Saj znaš pred rep postaviti dva elementa naenkrat? (Je enako, kot da bi ju vzel stran.)==
je strožji od operatorja =
v smislu, da je za slednjega dovolj,
@@ -23,8 +37,7 @@ implicitno že kar v argumentih predikata (glavi stavka).
Vse kaže, da tvoj predikat vedno vrne false
. Si mu dal pravilno ime, si se morda pri imenu zatipkal?
Vse kaže, da tvoj predikat vedno vrne "false". Si mu dal pravilno ime, si se morda pri imenu zatipkal?
Če je ime pravilno, se morda splača preveriti tudi, če se nisi zatipkal kje drugje, je morda kakšna pika namesto vejice ali obratno, morda kakšna spremenljivka z malo začetnico?
Možno je seveda tudi, da so tvoji pogoji prestrogi ali celo nemogoči (kot bi bila npr. zahteva,
-da je X
hkrati starš in sestra od Y
ali kaj podobno zlobnega).
N
enako kot N + 1
ali kaj podobno logično zlobnega).
''',
'timeout': '''\
@@ -45,30 +58,40 @@ da je X
hkrati starš in sestra od Y
ali kaj podobno z
''',
'bad_[]_case': '''\
-bad_[]_case
+Kaj je rezultat, če vstaviš nek element v prazen seznam? Gotovo ne prazen seznam ali celo karkoli (spremenljivka +brez določene vrednosti).
''', 'returns_elem_instead_of_list': '''\ -returns_elem_instead_of_list
+Vrniti moraš seznam, ne element.
''', 'maxEl_base_case_missing': '''\ -maxEl_base_case_missing
+Rešitev je skoraj pravilna. Ampak mislim, da si pozabil na en poseben primer. Kaj se zgodi, če vstavljaš v seznam +nov največji element? Poskusi spodnji klic.
+?- sins(9, [1,2,3,4,5], L).
x_and_head_swapped
+Hmmm, v kakšnem vrstnem redu morata biti nov element in trenutna glava seznama?
+?- sins(3, [1,2,4,5,6], L).
duplicates_incorrect
+Si pozabil, da seznam dovoljuje tudi vstavljanje duplikatov? Prvi klic spodaj deluje, drugi ne.
+?- sins(3, [1,2,4,5,6], L).
?- sins(3, [1,2,3,4,5], L).
unprotected_branch
+Si "zaščitil" (s pogojem) obe možnosti (veji)? Pazi, če ena nima pogoja, bo prva rešitev verjetno pravilna, vendar +pa bodo možne še druge rešitve, ki ne bodo. Podpičje pomeni logični OR in ne logični XOR. Kar pomeni, da lahko prolog +poišče alternative v drugi veji, čeprav je pogoj v prvi veji izpolnjen! Zato sta potrebna oba pogoja.
''', 'forgotten_heads': '''\ -forgotten_heads
+Si pozabil v seznam vrniti glave, ki si jih pred vstopom v rekurzijo dal na sklad? Tudi jaz sem jih... ;)
+Poglej kaj se zgodi ob spodnjem vprašanju in ti bo takoj vse jasno.
+?- sins(4, [1,2,3,5,6], L).