diff options
author | Aleksander Sadikov <aleksander.sadikov@fri.uni-lj.si> | 2016-03-21 18:44:28 +0100 |
---|---|---|
committer | Aleksander Sadikov <aleksander.sadikov@fri.uni-lj.si> | 2016-03-21 18:44:28 +0100 |
commit | 8eb67a4b388698f01b06cdf6a1a7935ab166ab34 (patch) | |
tree | eb0ad5fcff8df402e10a5db03ec9cea37fe85a11 /prolog/problems | |
parent | bf1447e2f16267283db600758384e2d9d3ac2c5d (diff) |
Hints and plans for min/2 added.
Diffstat (limited to 'prolog/problems')
-rw-r--r-- | prolog/problems/lists_advanced/max_2/sl.py | 2 | ||||
-rw-r--r-- | prolog/problems/lists_advanced/min_2/sl.py | 39 |
2 files changed, 31 insertions, 10 deletions
diff --git a/prolog/problems/lists_advanced/max_2/sl.py b/prolog/problems/lists_advanced/max_2/sl.py index 07431d6..cb67fd1 100644 --- a/prolog/problems/lists_advanced/max_2/sl.py +++ b/prolog/problems/lists_advanced/max_2/sl.py @@ -19,7 +19,7 @@ plan = ['''\ ki je večji zmaga in ga vrneš!</p> ''', '''\ <p>Če je podani seznam <code>L</code> sestavljen iz glave <code>H</code> in repa <code>T</code> ter predpostavimo, -da je največji element v <code>T</code> enak <code>MaxT</code>. Če dalje velja še, da je vrednost <code>H</code> +da je največji element v <code>T</code> enak <code>MaxT</code> ter dalje velja še, da je vrednost <code>H</code> večja od <code>MaxT</code>, potem je <code>H</code> največji element v <code>L</code>. <em>Ali</em> pa velja, da je vrednost <code>H</code> manjša od <code>MaxT</code>, v tem primeru pa je <code>MaxT</code> največji element v <code>L</code>.</p> diff --git a/prolog/problems/lists_advanced/min_2/sl.py b/prolog/problems/lists_advanced/min_2/sl.py index 8f80e3f..d318807 100644 --- a/prolog/problems/lists_advanced/min_2/sl.py +++ b/prolog/problems/lists_advanced/min_2/sl.py @@ -1,3 +1,5 @@ +# coding=utf-8 + name = 'min/2' slug = 'Poišči najmanjši element v danem seznamu' @@ -10,6 +12,19 @@ description = '''\ M = 2. </pre>''' +plan = ['''\ +<p>Kot vedno, poskusi prevesti na manjši problem. Recimo, da že imaš <em>najmanjši</em> element v repu seznama...</p> +''', '''\ +<p>Najmanjši element v repu (seznamu brez glave <code>H</code>) primerjaj z vrednostjo glave <code>H</code>, tisti, +ki je manjši zmaga in ga vrneš!</p> +''', '''\ +<p>Če je podani seznam <code>L</code> sestavljen iz glave <code>H</code> in repa <code>T</code> ter predpostavimo, +da je najmanjši element v <code>T</code> enak <code>MinT</code> ter dalje velja še, da je vrednost <code>H</code> +manjša od <code>MinT</code>, potem je <code>H</code> najmanjši element v <code>L</code>. <em>Ali</em> pa velja, da je +vrednost <code>H</code> večja od <code>MinT</code>, v tem primeru pa je <code>MinT</code> najmanjši element v +<code>L</code>.</p> +'''] + hint = { 'eq_instead_of_equ': '''\ <p>Operator <code>==</code> je strožji od operatorja <code>=</code> v smislu, da je za slednjega dovolj, @@ -24,8 +39,7 @@ implicitno že kar v argumentih predikata (glavi stavka).</p> ''', 'base_case': '''\ -<p>Si pomislil na robni pogoj? Kaj je najbolj enostaven primer, ko je element v seznamu? -Do katerega elementa najlažje prideš?</p> +<p>Si pomislil na robni pogoj? Kaj je najkrajši seznam, ki ima očiten najmanjši element?</p> ''', 'recursive_case': '''\ @@ -37,7 +51,7 @@ Do katerega elementa najlažje prideš?</p> <p>Č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?</p> <p>Možno je seveda tudi, da so tvoji pogoji prestrogi ali celo nemogoči (kot bi bila npr. zahteva, -da je <code>X</code> hkrati starš in sestra od <code>Y</code> ali kaj podobno zlobnega).</p> +da je <code>N</code> enako kot <code>N + 1</code> ali kaj podobno logično zlobnega).</p> ''', 'timeout': '''\ @@ -46,26 +60,33 @@ da je <code>X</code> hkrati starš in sestra od <code>Y</code> ali kaj podobno z ''', 'empty_list_base_case': '''\ -<p>empty_list_base_case</p> +<p>V praznem seznamu boš težko našel najmanjši element. Kaj, če se tokrat ustaviš malo prej?</p> ''', 'list_instead_of_elem_base_case': '''\ -<p>list_instead_of_elem_base_case</p> +<p>Vrni element in ne seznam!</p> ''', 'duplicates_not_covered': '''\ -<p>duplicates_not_covered</p> +<p>Si pomislil, da so v seznamu lahko tudi duplikati?</p> ''', 'args_not_instantiated': '''\ -<p>args_not_instantiated</p> +<p>Napaka, ki si jo dobil od prologa, pomeni, da ob uporabi aritmetike niso podane vse vrednosti spremenljivk.</p> +<p>Si morda pozabil, da konjunkcija veže močneje od disjunkcije oz. da je vsak prologov stavek (veja, pravilo) +samostojen v smislu dosega spremenljivk? Morda je to problem. Pozorno poglej oba bloka kode (pred in za podpičjem), +oziroma obe pravili.</p> ''', 'unprotected_branch': '''\ -<p>unprotected_branch</p> +<p>Zdi se mi, da si pozabil "zaščititi" eno izmed obeh vej. Obe veji (disjunkciji) potrebujeta pogoj, ne zanašaj se +na to, da če je prišel v drugo vejo, potem prva ne velja. Velja OR in ne XOR. Zato jih moraš ti narediti +ekskluzivne. Poskusi tole vprašanje in poglej <em>vse možne</em> rešitve, boš videl v čem je problem.</p> +<p><code>?- min([1,9,3,8,6], Min).</code></p> ''', 'one_branch_missing': '''\ -<p>one_branch_missing</p> +<p>Si morda pozabil na eno izmed možnosti? Glava je lahko <em>ali</em> večja <em>ali</em> manjša od +najmanjšega elementa v repu.</p> ''', } |