<?xml version="1.0"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0//EN"
  "http://www.w3.org/TR/MathML2/dtd/xhtml-math11-f.dtd"
  [<!ENTITY mathml "http://www.w3.org/1998/Math/MathML">
   <!ENTITY CLin "<mo class='builtin' lspace='thickmathspace' rspace='thickmathspace'>&epsiv;</mo>">]>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Clausal Language (ver. 5.81.19, by P.J. Voda, J. Komara, J. Kluka)</title
>
<script type="text/javascript" src="ajax.js"></script>
<script type="text/javascript" src="formdata2querystring.js"></script>
<script type="text/javascript" src="submit-update.js"></script>
<link rel="stylesheet" type="text/css" href="default.css" title="Default"/>
<link rel="alternate stylesheet" type="text/css" href="embers.css" title="Embers"
/>
</head>
<body>
<div id="_updater_" name="_edit_updater_">...
</div>
<div id="_main_editor_">
<form action="#" method="POST" class="quit_box"><input type="hidden" name="action"
 value="quit"/><input type="hidden" name="selector" value="id------"/><button
 type="submit" name="name" value="File" accesskey="f" title="Alt+Shift+F" class="quit"
 onclick="return submitForm(this.form,this);"><span class="acskey">F</span>ile</button
><button type="submit" name="name" value="Save" accesskey="s" title="Alt+Shift+S"
 class="quit" onclick="return submitForm(this.form,this);"><span class="acskey"
>S</span>ave</button><button type="submit" name="name" value="Setup" accesskey="u"
 title="Alt+Shift+U" class="quit" onclick="return submitForm(this.form,this);"
>Set<span class="acskey">u</span>p</button><button type="submit" name="name"
 value="Recompile" accesskey="r" title="Alt+Shift+R" class="quit" onclick="return submitForm(this.form,this);"
><span class="acskey">R</span>ecompile</button><button type="submit" name="name"
 value="Reexec. Query" accesskey="q" title="Alt+Shift+Q" class="quit" onclick="return submitForm(this.form,this);"
>Reexec. <span class="acskey">Q</span>uery</button><button type="submit" name="name"
 value="Save &amp; Exit" accesskey="x" title="Alt+Shift+X" class="quit" onclick="return submitForm(this.form,this);"
>Save &amp; E<span class="acskey">x</span>it</button><input type="hidden" name="xoff"
 value="0"/><input type="hidden" name="yoff" value="0"/>
</form>
<div class="framed1">
<div class="framename">Clausal Language (ver. 5.81.19, by P.J. Voda, J. Komara, J. Kluka)
</div>
<div id="idD-----">
<div id="idE-----" class="editable">
<div id="idF-----"/>
</div>
<div id="idG-----" class="editable">
<div id="idH-----"/>
</div>
<div id="idI-----" class="editable">
<div id="idJ-----"/>
</div>
</div>
<div id="idL-----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Module&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr">Ex03b</mi>
</math></span>
</div>
<div class="editbuttontd">
<form action="#idL-----" method="POST" id="idL-----__" onsubmit="return submitForm(this,this);"
><a name="idL-----"/><input type="hidden" name="selector" value="idL-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
<div id="idM-----">
<div id="idN-----" class="editable"><a name="idP-----"/>
<form action="#idP-----" method="POST" id="idP-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idP-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idQ-----" class="fill"><a name="idQ-----"/><span class="header">Included module&nbsp;<math
 xmlns="&mathml;">
<mi class="comp_id_hdr">Standard</mi>
</math></span>
</div>
</div>
<div id="idR-----" class="editable"><a name="idT-----"/>
<form action="#idT-----" method="POST" id="idT-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idT-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idU-----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>3. CVIČENIE Z PREDMETU ÚVOD DO DEKLARATÍVNEHO PROGRAMOVANIA 2011/2012</b
>
</p>
<p><b>ČASŤ B</b>
</p>
<p>http://ii.fmph.uniba.sk/cl/courses/1-AIN-505-udp/1112ls/ex/ex03.zip
</p>
</div>
<div class="editbuttontd">
<form action="#idU-----" method="POST" id="idU-----__" onsubmit="return submitForm(this,this);"
><a name="idU-----"/><input type="hidden" name="selector" value="idU-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idV-----" class="editable"><a name="idX-----"/>
<form action="#idX-----" method="POST" id="idX-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idX-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idY-----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Dátum:</i> 27. 2. 2012
</p>
<p><i>Odporúčaná verzia CL:</i> <b>5.81.20</b>
</p>
<p><i>WWW stránka predmetu:</i> http://dai.fmph.uniba.sk/courses/udp
</p>
<p><i>Kontakt:</i> udp(zavináč)lists.dai.fmph.uniba.sk
</p>
</div>
<div class="editbuttontd">
<form action="#idY-----" method="POST" id="idY-----__" onsubmit="return submitForm(this,this);"
><a name="idY-----"/><input type="hidden" name="selector" value="idY-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idZ-----" class="editable"><a name="idb-----"/>
<form action="#idb-----" method="POST" id="idb-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idb-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idc-----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úvodná poznámka.</b> Toto cvičenie je venované priraďujúcim diskrimináciám
 (<i>ex03a</i>) a simulácii cyklov chvostovou rekurziou (<i>ex03b</i>).
</p>
</div>
<div class="editbuttontd">
<form action="#idc-----" method="POST" id="idc-----__" onsubmit="return submitForm(this,this);"
><a name="idc-----"/><input type="hidden" name="selector" value="idc-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idd-----" class="editable"><a name="idf-----"/>
<form action="#idf-----" method="POST" id="idf-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idf-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idg-----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Literatúra.</i>
</p>
<p>[1] J. Kľuka. Prednášky z Úvodu do deklaratívneho programovania LS 2011/2012.
</p>
<p class="indented">http://ii.fmph.uniba.sk/cl/courses/1-AIN-505-udp/1112ls/udp-screen.pdf
</p>
<p>[2] D. Guller. Poznámky k prednáškam z CL.
</p>
<p>[3] J. Komara and P. J. Voda. Metamathematics of Computer Programming. 2001.
</p>
</div>
<div class="editbuttontd">
<form action="#idg-----" method="POST" id="idg-----__" onsubmit="return submitForm(this,this);"
><a name="idg-----"/><input type="hidden" name="selector" value="idg-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idh-----" class="editable"><a name="idj-----"/>
<form action="#idj-----" method="POST" id="idj-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idj-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idk-----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Poznámka.</i> Nadpisy sú číslované podľa [1].
</p>
</div>
<div class="editbuttontd">
<form action="#idk-----" method="POST" id="idk-----__" onsubmit="return submitForm(this,this);"
><a name="idk-----"/><input type="hidden" name="selector" value="idk-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idl-----" class="editable"><a name="idn-----"/>
<form action="#idn-----" method="POST" id="idn-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idn-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="ido-----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p>Preskočte nasledujúce komponenty po nadpis „CVIČENIE“.
</p>
</div>
<div class="editbuttontd">
<form action="#ido-----" method="POST" id="ido-----__" onsubmit="return submitForm(this,this);"
><a name="ido-----"/><input type="hidden" name="selector" value="ido-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idp-----" class="editable"><a name="idr-----"/>
<form action="#idr-----" method="POST" id="idr-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idr-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="ids-----" class="fill"><a name="ids-----"/><span class="header">Application display&nbsp;<em
>Tex0_foo</em>&nbsp;/&nbsp;0: <math xmlns="&mathml;">
<mi>?</mi>
<mfenced><mi>&ctdot;</mi>
</mfenced>
</math></span>
</div>
</div>
<div id="idt-----" class="editable"><a name="idv-----"/>
<form action="#idv-----" method="POST" id="idv-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idv-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idw-----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<acronym title="This function is a constructor"
 class="fun_constr"><math xmlns="&mathml;">
<mi class="inh_col_id">Foo</mi>
</math></acronym>&nbsp;/&nbsp;0 displayed by&nbsp;<em>Tex0_foo</em> as&nbsp;<math
 xmlns="&mathml;">
<mi class="adident">?</mi>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="adident">?</mi><mo>=</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idw-----" method="POST" id="idw-----__" onsubmit="return submitForm(this,this);"
><a name="idw-----"/><input type="hidden" name="selector" value="idw-----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idx-----" class="editable"><a name="idz-----"/>
<form action="#idz-----" method="POST" id="idz-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idz-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id0-----" class="fill"><a name="id0-----"/><span class="header">Application display&nbsp;<em
>Tex0_cdots</em>&nbsp;/&nbsp;0: <math xmlns="&mathml;">
<mo>&ctdot;</mo>
</math></span>
</div>
</div>
<div id="id1-----" class="editable"><a name="id3-----"/>
<form action="#id3-----" method="POST" id="id3-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id3-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id4-----" class="fill"><a name="id4-----"/><span class="header">Application display&nbsp;<em
>Tex1_cdots</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<mo>&ctdot;</mo>
</math></span>
</div>
</div>
<div id="id5-----" class="editable"><a name="id7-----"/>
<form action="#id7-----" method="POST" id="id7-----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id7-----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id8-----" class="fill"><a name="id8-----"/><span class="header">Application display&nbsp;<em
>Tex0_ast</em>&nbsp;/&nbsp;0: <math xmlns="&mathml;">
<mo>&ast;</mo>
</math></span>
</div>
</div>
<div id="id9-----" class="editable"><a name="id-A----"/>
<form action="#id-A----" method="POST" id="id-A----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id-A----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idAA----" class="fill"><a name="idAA----"/><span class="header">Application display&nbsp;<em
>Tex1_cdots_around</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<mo>&ctdot;</mo>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub><mo>&ctdot;</mo>
</math></span>
</div>
</div>
<div id="idBA----" class="editable"><a name="idDA----"/>
<form action="#idDA----" method="POST" id="idDA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idDA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idEA----" class="fill"><a name="idEA----"/><span class="header">Application display&nbsp;<em
>Tex1_f</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<mi>f</mi>
<mfenced><mi>&ctdot;</mi>
</mfenced>
</math></span>
</div>
</div>
<div id="idFA----" class="editable"><a name="idHA----"/>
<form action="#idHA----" method="POST" id="idHA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idHA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idIA----" class="fill"><a name="idIA----"/><span class="header">Application display&nbsp;<em
>Tex2_cdots</em>&nbsp;/&nbsp;2: <math xmlns="&mathml;">
<mo>&ctdot;</mo>
</math></span>
</div>
</div>
<div id="idJA----" class="editable"><a name="idLA----"/>
<form action="#idLA----" method="POST" id="idLA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idLA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idMA----" class="fill"><a name="idMA----"/><span class="header">Application display&nbsp;<em
>Tex2_equiv</em>&nbsp;/&nbsp;2: <math xmlns="&mathml;">
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub><mo>&equiv;</mo>
<msub class="ad_constr_arg"><mi>#</mi><mn>2</mn>
</msub>
</math></span>
</div>
</div>
<div id="idNA----" class="editable"><a name="idPA----"/>
<form action="#idPA----" method="POST" id="idPA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idPA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idQA----" class="fill"><a name="idQA----"/><span class="header">Application display&nbsp;<em
>Tex1_fact</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub><mo>!</mo>
</math></span>
</div>
</div>
<div id="idRA----" class="editable"><a name="idTA----"/>
<form action="#idTA----" method="POST" id="idTA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idTA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idUA----" class="fill"><a name="idUA----"/><span class="header">Application display&nbsp;<em
>Tex2_exp</em>&nbsp;/&nbsp;2: <math xmlns="&mathml;">
<msup>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub>
<msub class="ad_constr_arg"><mi>#</mi><mn>2</mn>
</msub>
</msup>
</math></span>
</div>
</div>
<div id="idVA----" class="editable"><a name="idXA----"/>
<form action="#idXA----" method="POST" id="idXA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idXA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idYA----" class="fill"><a name="idYA----"/><span class="header">Application display&nbsp;<em
>Tex1_fib</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<msub><mi mathvariant="normal">fib</mi>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub>
</msub>
</math></span>
</div>
</div>
<div id="idZA----" class="editable"><a name="idbA----"/>
<form action="#idbA----" method="POST" id="idbA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idbA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idcA----" class="fill"><a name="idcA----"/><span class="header">Application display&nbsp;<em
>Tex1_fib_efficient</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<msubsup><mi mathvariant="normal">fib</mi>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub><mi mathvariant="normal">efficient</mi>
</msubsup>
</math></span>
</div>
</div>
<div id="iddA----" class="editable"><a name="idfA----"/>
<form action="#idfA----" method="POST" id="idfA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idfA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idgA----" class="fill"><a name="idgA----"/><span class="header">Application display&nbsp;<em
>Tex1_f1_efficient</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub>
</math></span>
</div>
</div>
<div id="idhA----" class="editable"><a name="idjA----"/>
<form action="#idjA----" method="POST" id="idjA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idjA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idkA----" class="fill"><a name="idkA----"/><span class="header">Application display&nbsp;<em
>Tex1_f2_efficient</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub>
</math></span>
</div>
</div>
<div id="idlA----" class="editable"><a name="idnA----"/>
<form action="#idnA----" method="POST" id="idnA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idnA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idoA----" class="fill"><a name="idoA----"/><span class="header">Application display&nbsp;<em
>Tex1_f3_efficient</em>&nbsp;/&nbsp;1: <math xmlns="&mathml;">
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<msub class="ad_constr_arg"><mi>#</mi><mn>1</mn>
</msub>
</math></span>
</div>
</div>
<div id="idpA----" class="editable"><a name="idrA----"/>
<form action="#idrA----" method="POST" id="idrA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idrA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idsA----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>C V I Č E N I E</b>
</p>
</div>
<div class="editbuttontd">
<form action="#idsA----" method="POST" id="idsA----__" onsubmit="return submitForm(this,this);"
><a name="idsA----"/><input type="hidden" name="selector" value="idsA----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idtA----" class="editable"><a name="idvA----"/>
<form action="#idvA----" method="POST" id="idvA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idvA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idwA----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>7. SIMULÁCIA CYKLOV CHVOSTOVOU REKURZIOU</b>
</p>
</div>
<div class="editbuttontd">
<form action="#idwA----" method="POST" id="idwA----__" onsubmit="return submitForm(this,this);"
><a name="idwA----"/><input type="hidden" name="selector" value="idwA----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idxA----" class="editable"><a name="idzA----"/>
<form action="#idzA----" method="POST" id="idzA----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idzA----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id0A----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Poznámka.</i> Podrobnejší návod na riešenie nasledujúcich úloh 
nájdete napríklad v prednáškach [1].
</p>
<p>Úlohy označené hviezdičkou <b><math xmlns="&mathml;">
<mo>&ast;</mo>
</math></b> riešte <b>po</b> vyriešení všetkých neoznačených úloh.
</p>
</div>
<div class="editbuttontd">
<form action="#id0A----" method="POST" id="id0A----__" onsubmit="return submitForm(this,this);"
><a name="id0A----"/><input type="hidden" name="selector" value="id0A----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id1A----" class="editable"><a name="id3A----"/>
<form action="#id3A----" method="POST" id="id3A----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id3A----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id4A----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>7.1 Simulácia while cyklu</b>
</p>
</div>
<div class="editbuttontd">
<form action="#id4A----" method="POST" id="id4A----__" onsubmit="return submitForm(this,this);"
><a name="id4A----"/><input type="hidden" name="selector" value="id4A----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id5A----" class="editable"><a name="id7A----"/>
<form action="#id7A----" method="POST" id="id7A----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id7A----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id8A----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Výpočet faktoriálu while cyklom.</i> Funkciu <math xmlns="&mathml;"
>
<mi class="ident">Fact</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<mrow><mi>n</mi><mo>!</mo>
</mrow>
</math>
</p>
<div style="margin-left: 2em">
<math xmlns="&mathml;" mode="display" class="clause">
<mrow><mn class="builtin">0</mn><mo>!</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo class="builtin">+</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo>!</mo>
</mrow><mo>=</mo>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo class="builtin">&sdot;</mo>
<mrow><mi>n</mi><mo>!</mo>
</mrow>
</math>
</div>
<p>vypočítame pomocou pascalovského while cyklu nasledovne:
</p><pre>    f := 1;                  }  Fact
    while n &lt;&gt; 0 do begin   -
        f := f*n;            |
        n := n-1             |- While_fact
    end;                     |
    Result := f             -</pre>
</div>
<div class="editbuttontd">
<form action="#id8A----" method="POST" id="id8A----__" onsubmit="return submitForm(this,this);"
><a name="id8A----"/><input type="hidden" name="selector" value="id8A----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id9A----" class="editable"><a name="id-B----"/>
<form action="#id-B----" method="POST" id="id-B----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id-B----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idAB----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha. Faktoriál simuláciou while cyklu.</b> Simulujte uvedený while
 cyklus chvostovorekurzívnou funkciou <math xmlns="&mathml;">
<mi class="ident">While_fact</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>,</mo><mi>f</mi><mo>)</mo>
</mrow>
</math> a použite ju na zadefinovanie funkcie <math xmlns="&mathml;">
<mi class="ident">Fact</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<mrow><mi>n</mi><mo>!</mo>
</mrow>
</math>. Pomocný argument <math xmlns="&mathml;">
<mi>f</mi>
</math> nazývame <i>akumulátor</i>.
</p>
<p class="indented">Ako je naznačené vyššie, funkcia <math xmlns="&mathml;"
>
<mi class="ident">While_fact</mi>
</math> počíta iba cyklus a vrátenie výsledku.
</p>
<p class="indented">Hlavná funkcia <math xmlns="&mathml;">
<mi class="ident">Fact</mi>
</math> inicializuje akumulátor <math xmlns="&mathml;">
<mi>f</mi>
</math> vhodným volaním funkcie <math xmlns="&mathml;">
<mi class="ident">While_fact</mi>
</math>.
</p>
<p class="indented">Invariant:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">While_fact</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>,</mo><mi>f</mi><mo>)</mo>
</mrow><mo>=</mo><mi>f</mi><mo class="builtin">&sdot;</mo>
<mrow><mi>n</mi><mo>!</mo>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idAB----" method="POST" id="idAB----__" onsubmit="return submitForm(this,this);"
><a name="idAB----"/><input type="hidden" name="selector" value="idAB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idBB----" class="editable"><a name="idDB----"/>
<form action="#idDB----" method="POST" id="idDB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idDB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idEB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">While_fact</mi>
</math></span>&nbsp;/&nbsp;2</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">While_fact</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>f</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idEB----" method="POST" id="idEB----__" onsubmit="return submitForm(this,this);"
><a name="idEB----"/><input type="hidden" name="selector" value="idEB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idFB----" class="editable"><a name="idHB----"/>
<form action="#idHB----" method="POST" id="idHB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idHB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idIB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fact</mi>
</math></span> displayed by&nbsp;<em>Tex1_fact</em> as&nbsp;<math xmlns="&mathml;"
>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>!</mo>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>!</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idIB----" method="POST" id="idIB----__" onsubmit="return submitForm(this,this);"
><a name="idIB----"/><input type="hidden" name="selector" value="idIB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idJB----" class="editable"><a name="idLB----"/>
<form action="#idLB----" method="POST" id="idLB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idLB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idMB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fact_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Fact_test</mi><mo>=</mo>
<mrow><mn class="builtin">0</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">1</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">2</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">3</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">4</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">5</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">6</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo>
<mrow><mn class="builtin">7</mn><mo>!</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idMB----" method="POST" id="idMB----__" onsubmit="return submitForm(this,this);"
><a name="idMB----"/><input type="hidden" name="selector" value="idMB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idNB----" class="editable"><a name="idPB----"/>
<form action="#idPB----" method="POST" id="idPB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idPB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idQB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fact_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Fact_result</mi><mo>=</mo><mn class="builtin">1</mn><mo class="builtin"
>,</mo><mn class="builtin">1</mn><mo class="builtin">,</mo><mn class="builtin"
>2</mn><mo class="builtin">,</mo><mn class="builtin">6</mn><mo class="builtin"
>,</mo><mn class="builtin">24</mn><mo class="builtin">,</mo><mn class="builtin"
>120</mn><mo class="builtin">,</mo><mn class="builtin">720</mn><mo class="builtin"
>,</mo><mn class="builtin">5040</mn><mo class="builtin">,</mo><mn class="builtin"
>0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idQB----" method="POST" id="idQB----__" onsubmit="return submitForm(this,this);"
><a name="idQB----"/><input type="hidden" name="selector" value="idQB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idRB----" class="editable"><a name="idTB----"/>
<form action="#idTB----" method="POST" id="idTB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idTB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idUB----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha. Umocnenie simuláciou while cyklu.</b> Naprogramujte umocnenie
 pomocou simulácie while cyklu.
</p>
<p><b>a)</b> Do nasledujúcej poznámky vpíšte fragment pascalovského programu,
 ktorý vypočíta umocnenie do akumulátora <math xmlns="&mathml;">
<mi>e</mi>
</math>, podobne ako pri faktoriáli.
</p>
</div>
<div class="editbuttontd">
<form action="#idUB----" method="POST" id="idUB----__" onsubmit="return submitForm(this,this);"
><a name="idUB----"/><input type="hidden" name="selector" value="idUB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idVB----" class="editable"><a name="idXB----"/>
<form action="#idXB----" method="POST" id="idXB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idXB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idYB----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div><pre><span class="fge">e := ...;
while ... do begin
    ...
end;
Result := e</span></pre>
</div>
<div class="editbuttontd">
<form action="#idYB----" method="POST" id="idYB----__" onsubmit="return submitForm(this,this);"
><a name="idYB----"/><input type="hidden" name="selector" value="idYB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idZB----" class="editable"><a name="idbB----"/>
<form action="#idbB----" method="POST" id="idbB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idbB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idcB----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>b)</b> Zadefinujte chvostovorekurzívnu funkciu <math xmlns="&mathml;"
>
<mi class="ident">While_exp</mi>
<mrow class="cp1"><mo>(</mo><mi>x</mi><mo class="builtin">,</mo><mi>y</mi><mo
 class="builtin">,</mo><mi>e</mi><mo>)</mo>
</mrow>
</math>, ktorá simuluje váš while cyklus, ale nie inicializáciu akumulátora.
</p>
<p class="indented">Invariant:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">While_exp</mi>
<mrow class="cp1"><mo>(</mo><mi>x</mi><mo class="builtin">,</mo><mi>y</mi><mo
 class="builtin">,</mo>
<msup><mi>x</mi><mi>z</mi>
</msup><mo>)</mo>
</mrow><mo>=</mo>
<msup><mi>x</mi>
<mrow><mi>y</mi><mo class="builtin">+</mo><mi>z</mi>
</mrow>
</msup>
</math>
</div>
<div class="editbuttontd">
<form action="#idcB----" method="POST" id="idcB----__" onsubmit="return submitForm(this,this);"
><a name="idcB----"/><input type="hidden" name="selector" value="idcB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="iddB----" class="editable"><a name="idfB----"/>
<form action="#idfB----" method="POST" id="idfB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idfB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idgB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">While_exp</mi>
</math></span>&nbsp;/&nbsp;3</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">While_exp</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>y</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>e</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idgB----" method="POST" id="idgB----__" onsubmit="return submitForm(this,this);"
><a name="idgB----"/><input type="hidden" name="selector" value="idgB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idhB----" class="editable"><a name="idjB----"/>
<form action="#idjB----" method="POST" id="idjB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idjB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idkB----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>c)</b> Funkcia <math xmlns="&mathml;">
<mi class="ident">Exp</mi>
<mrow class="cp1"><mo>(</mo><mi>x</mi><mo class="builtin">,</mo><mi>y</mi><mo
>)</mo>
</mrow><mo>&equiv;</mo>
<msup><mi>x</mi><mi>y</mi>
</msup>
</math> odštartuje simuláciu while cyklu s vhodnou začiatočnou hodnotou 
akumulátora <math xmlns="&mathml;">
<mi>e</mi>
</math>.
</p>
</div>
<div class="editbuttontd">
<form action="#idkB----" method="POST" id="idkB----__" onsubmit="return submitForm(this,this);"
><a name="idkB----"/><input type="hidden" name="selector" value="idkB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idlB----" class="editable"><a name="idnB----"/>
<form action="#idnB----" method="POST" id="idnB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idnB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idoB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Exp</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_exp</em> as&nbsp;<math
 xmlns="&mathml;">
<msup>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</msup>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msup>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mstyle class="bvar"><mi>y</mi>
</mstyle>
</msup><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idoB----" method="POST" id="idoB----__" onsubmit="return submitForm(this,this);"
><a name="idoB----"/><input type="hidden" name="selector" value="idoB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idpB----" class="editable"><a name="idrB----"/>
<form action="#idrB----" method="POST" id="idrB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idrB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idsB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Exp_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Exp_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<msup><mn class="builtin">0</mn><mn class="builtin">0</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">1</mn><mn class="builtin">0</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">2</mn><mn class="builtin">0</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">5</mn><mn class="builtin">0</mn>
</msup><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msup><mn class="builtin">0</mn><mn class="builtin">1</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">1</mn><mn class="builtin">1</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">2</mn><mn class="builtin">1</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">5</mn><mn class="builtin">1</mn>
</msup><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msup><mn class="builtin">0</mn><mn class="builtin">10</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">1</mn><mn class="builtin">10</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">2</mn><mn class="builtin">10</mn>
</msup><mo class="builtin">,</mo>
<msup><mn class="builtin">5</mn><mn class="builtin">10</mn>
</msup><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idsB----" method="POST" id="idsB----__" onsubmit="return submitForm(this,this);"
><a name="idsB----"/><input type="hidden" name="selector" value="idsB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idtB----" class="editable"><a name="idvB----"/>
<form action="#idvB----" method="POST" id="idvB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idvB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idwB----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Exp_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Exp_result</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo class="builtin">,</mo
><mn class="builtin">1</mn><mo class="builtin">,</mo><mn class="builtin">1</mn
><mo class="builtin">,</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo class="builtin">,</mo
><mn class="builtin">1</mn><mo class="builtin">,</mo><mn class="builtin">2</mn
><mo class="builtin">,</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo class="builtin">,</mo
><mn class="builtin">1</mn><mo class="builtin">,</mo><mn class="builtin">1024</mn
><mo class="builtin">,</mo><mn class="builtin">9765625</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idwB----" method="POST" id="idwB----__" onsubmit="return submitForm(this,this);"
><a name="idwB----"/><input type="hidden" name="selector" value="idwB----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idxB----" class="editable"><a name="idzB----"/>
<form action="#idzB----" method="POST" id="idzB----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idzB----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id0B----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>7.2 Efektívny výpočet Fibonacciho postupnosti</b>
</p>
</div>
<div class="editbuttontd">
<form action="#id0B----" method="POST" id="id0B----__" onsubmit="return submitForm(this,this);"
><a name="id0B----"/><input type="hidden" name="selector" value="id0B----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id1B----" class="editable"><a name="id3B----"/>
<form action="#id3B----" method="POST" id="id3B----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id3B----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id4B----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Efektívny výpočet členov Fibonacciho postupnosti while cyklom.</i>
 Funkciu <math xmlns="&mathml;">
<mi class="ident">Fib</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msub><mi mathvariant="normal">fib</mi><mi>n</mi>
</msub>
</math> pre <math xmlns="&mathml;">
<mi>n</mi>
</math>-tý člen Fibonacciho postupnosti
</p>
</div>
<div class="editbuttontd">
<form action="#id4B----" method="POST" id="id4B----__" onsubmit="return submitForm(this,this);"
><a name="id4B----"/><input type="hidden" name="selector" value="id4B----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id5B----" class="editable"><a name="id7B----"/>
<form action="#id7B----" method="POST" id="id7B----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id7B----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id8B----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fib</mi>
</math></span> displayed by&nbsp;<em>Tex1_fib</em> as&nbsp;<math xmlns="&mathml;"
>
<msub><mi mathvariant="normal">fib</mi>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
</msub>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">0</mn>
</msub><mo>=</mo><mn class="builtin">0</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">1</mn>
</msub><mo>=</mo><mn class="builtin">1</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub><mi mathvariant="normal">fib</mi>
<mrow>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo class="builtin">+</mo><mn class="builtin">2</mn>
</mrow>
</msub><mo>=</mo>
<msub><mi mathvariant="normal">fib</mi><mi>n</mi>
</msub><mo class="builtin">+</mo>
<msub><mi mathvariant="normal">fib</mi>
<mrow><mi>n</mi><mo class="builtin">+</mo><mn class="builtin">1</mn>
</mrow>
</msub>
</math>
</div>
<div class="editbuttontd">
<form action="#id8B----" method="POST" id="id8B----__" onsubmit="return submitForm(this,this);"
><a name="id8B----"/><input type="hidden" name="selector" value="id8B----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id9B----" class="editable"><a name="id-C----"/>
<form action="#id-C----" method="POST" id="id-C----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id-C----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idAC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p>môžeme efektívne vypočítať pomocou <i>while</i> cyklu s dvoma akumulátormi
 <math xmlns="&mathml;">
<mi>m</mi>
</math>, <math xmlns="&mathml;">
<mi>d</mi>
</math>, v ktorých si pamätáme dva po sebe nasledujúce členy postupnosti:
</p><pre>    if n = 0 then                            -
        Result := 0                           |
    else begin                                |_ Fib_efficient
        n := n - 1; { !! }                    |
        m := 0; { fib(0) }                    |
        d := 1; { fib(1) }                   -
        while n &lt;&gt; 0 do begin                -
            { m = fib(i) &amp; d = fib(i+1) }     |
            m1 := d;                          |
            d1 := m+d;                        |
            m := m1; d := d1;                 |- While_fib
            { m = fib(i+1) &amp; d = fib(i+2) }   |
            n := n-1                          |
        end;                                  |
        Result := d                          -
    end</pre>
</div>
<div class="editbuttontd">
<form action="#idAC----" method="POST" id="idAC----__" onsubmit="return submitForm(this,this);"
><a name="idAC----"/><input type="hidden" name="selector" value="idAC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idBC----" class="editable"><a name="idDC----"/>
<form action="#idDC----" method="POST" id="idDC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idDC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idEC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha. Efektívny výpočet členov Fibonacciho postupnosti simuláciou
 while cyklu.</b>
</p>
<p><b>a)</b> Simulujte while cyklus z predchádzajúcej poznámky chvostovorekurzívnu
 funkciou <math xmlns="&mathml;">
<mi class="ident">While_fib</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>,</mo><mi>m</mi><mo>,</mo><mi>d</mi
><mo>)</mo>
</mrow>
</math>. Úvodný test a inicializáciu premenných zatiaľ neberte do úvahy.
</p>
<p class="indented">Invariant:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">While_fib</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>,</mo>
<msub><mi mathvariant="normal">fib</mi><mi>i</mi>
</msub><mo>,</mo>
<msub><mi mathvariant="normal">fib</mi>
<mrow><mi>i</mi><mo class="builtin">+</mo><mn class="builtin">1</mn>
</mrow>
</msub><mo>)</mo>
</mrow><mo>=</mo>
<msub><mi mathvariant="normal">fib</mi>
<mrow><mi>n</mi><mo class="builtin">+</mo><mi>i</mi><mo class="builtin">+</mo
><mn class="builtin">1</mn>
</mrow>
</msub>
</math>
</div>
<div class="editbuttontd">
<form action="#idEC----" method="POST" id="idEC----__" onsubmit="return submitForm(this,this);"
><a name="idEC----"/><input type="hidden" name="selector" value="idEC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idFC----" class="editable"><a name="idHC----"/>
<form action="#idHC----" method="POST" id="idHC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idHC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idIC----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">While_fib</mi>
</math></span>&nbsp;/&nbsp;3</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">While_fib</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>m</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>d</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idIC----" method="POST" id="idIC----__" onsubmit="return submitForm(this,this);"
><a name="idIC----"/><input type="hidden" name="selector" value="idIC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idJC----" class="editable"><a name="idLC----"/>
<form action="#idLC----" method="POST" id="idLC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idLC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idMC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>b)</b> Naprogramujte funkciu <math xmlns="&mathml;">
<mi class="ident">Fib_efficient</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msubsup><mi mathvariant="normal">fib</mi><mi>n</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
</math>, ktorá vykoná úvodný test pascalovského programu a spustí simuláciu
 while cyklu so správne inicializovanými hodnotami premenných <math xmlns="&mathml;"
>
<mi>n</mi>
</math>, <math xmlns="&mathml;">
<mi>a</mi>
</math>, <math xmlns="&mathml;">
<mi>b</mi>
</math>.
</p>
</div>
<div class="editbuttontd">
<form action="#idMC----" method="POST" id="idMC----__" onsubmit="return submitForm(this,this);"
><a name="idMC----"/><input type="hidden" name="selector" value="idMC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idNC----" class="editable"><a name="idPC----"/>
<form action="#idPC----" method="POST" id="idPC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idPC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idQC----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fib_efficient</mi>
</math></span> displayed by&nbsp;<em>Tex1_fib_efficient</em> as&nbsp;<math xmlns="&mathml;"
>
<msubsup><mi mathvariant="normal">fib</mi>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mi mathvariant="normal">efficient</mi>
</msubsup>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msubsup><mi mathvariant="normal">fib</mi>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mi mathvariant="normal">efficient</mi>
</msubsup><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idQC----" method="POST" id="idQC----__" onsubmit="return submitForm(this,this);"
><a name="idQC----"/><input type="hidden" name="selector" value="idQC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idRC----" class="editable"><a name="idTC----"/>
<form action="#idTC----" method="POST" id="idTC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idTC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idUC----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fib_efficient_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Fib_efficient_test</mi><mo>=</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">0</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">1</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">2</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">3</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">4</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">5</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">6</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">7</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">fib</mi><mn class="builtin">8</mn><mi mathvariant="normal"
>efficient</mi>
</msubsup><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idUC----" method="POST" id="idUC----__" onsubmit="return submitForm(this,this);"
><a name="idUC----"/><input type="hidden" name="selector" value="idUC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idVC----" class="editable"><a name="idXC----"/>
<form action="#idXC----" method="POST" id="idXC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idXC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idYC----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fib_efficient_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Fib_efficient_result</mi><mo>=</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">0</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">1</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">2</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">3</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">4</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">5</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">6</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">7</mn>
</msub><mo class="builtin">,</mo>
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">8</mn>
</msub><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idYC----" method="POST" id="idYC----__" onsubmit="return submitForm(this,this);"
><a name="idYC----"/><input type="hidden" name="selector" value="idYC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idZC----" class="editable"><a name="idbC----"/>
<form action="#idbC----" method="POST" id="idbC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idbC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idcC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><math xmlns="&mathml;">
<mo>&ast;</mo>
</math> Úloha.</b> Podobne ako v predchádzajúcej úlohe zadefinujte efektívnu
 verziu <math xmlns="&mathml;">
<mi class="ident">F1_efficient</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> nasledujúcej funkcie <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> simuláciou while cyklu.
</p>
</div>
<div class="editbuttontd">
<form action="#idcC----" method="POST" id="idcC----__" onsubmit="return submitForm(this,this);"
><a name="idcC----"/><input type="hidden" name="selector" value="idcC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="iddC----" class="editable"><a name="idfC----"/>
<form action="#idfC----" method="POST" id="idfC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idfC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idgC----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">F</mi><mn class="id_sub">1</mn
>
</msub>
</math></span></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">2</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo class="builtin">+</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo class="builtin">+</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo class="builtin">+</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>2</mn><mo>)</mo>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idgC----" method="POST" id="idgC----__" onsubmit="return submitForm(this,this);"
><a name="idgC----"/><input type="hidden" name="selector" value="idgC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idhC----" class="editable"><a name="idjC----"/>
<form action="#idjC----" method="POST" id="idjC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idjC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idkC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>a)</b> Do nasledujúcej poznámky vpíšte pascalovský program, ktorý
 počíta funkciu <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
</math> while cyklom. Výpočet je podobný výpočtu Fibonacciho postupnosti.
 Program si pamätá 3 po sebe nasledujúce členy postupnosti v akumulátoroch
 <math xmlns="&mathml;">
<mi>a</mi>
</math>, <math xmlns="&mathml;">
<mi>b</mi>
</math>, <math xmlns="&mathml;">
<mi>c</mi>
</math>.
</p>
</div>
<div class="editbuttontd">
<form action="#idkC----" method="POST" id="idkC----__" onsubmit="return submitForm(this,this);"
><a name="idkC----"/><input type="hidden" name="selector" value="idkC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idlC----" class="editable"><a name="idnC----"/>
<form action="#idnC----" method="POST" id="idnC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idnC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idoC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div><pre><span class="fge">if n = 0 then
    ...
else if n = 1 then
    ...
else begin
    n := ...;
    a := ...; { F1(0) }
    b := ...; { F1(1) }
    c := ...; { F1(2) }
    while ... do begin
        { a = F1(i) &amp; b = F1(i+1) &amp; c = F1(i+2) }
        ...
        { a = F1(i+1) &amp; b = F1(i+2) &amp; c = F1(i+3) }
    end;
    Result := c
end</span></pre>
</div>
<div class="editbuttontd">
<form action="#idoC----" method="POST" id="idoC----__" onsubmit="return submitForm(this,this);"
><a name="idoC----"/><input type="hidden" name="selector" value="idoC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idpC----" class="editable"><a name="idrC----"/>
<form action="#idrC----" method="POST" id="idrC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idrC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idsC----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>b)</b> Simulujte while cyklus funkciou <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">While_f</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>,</mo><mi>a</mi><mo>,</mo><mi>b</mi
><mo>,</mo><mi>c</mi><mo>)</mo>
</mrow>
</math>.
</p>
<p>Invariant:
</p>
<math xmlns="&mathml;" mode="display">
<msub class="ident"><mi class="ident">While_f</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo>)</mo>
</mrow><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo class="builtin">+</mo><mn class="builtin"
>2</mn><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mi>i</mi><mo
 class="builtin">+</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idsC----" method="POST" id="idsC----__" onsubmit="return submitForm(this,this);"
><a name="idsC----"/><input type="hidden" name="selector" value="idsC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idtC----" class="editable"><a name="idvC----"/>
<form action="#idvC----" method="POST" id="idvC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idvC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idwC----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">While_f</mi><mn class="id_sub"
>1</mn>
</msub>
</math></span>&nbsp;/&nbsp;4</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">While_f</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>b</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>c</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idwC----" method="POST" id="idwC----__" onsubmit="return submitForm(this,this);"
><a name="idwC----"/><input type="hidden" name="selector" value="idwC----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idxC----" class="editable"><a name="idzC----"/>
<form action="#idzC----" method="POST" id="idzC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idzC----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id0C----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>c)</b> Vo funkcii <math xmlns="&mathml;">
<mi class="ident">F1_efficient</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> ošetrite okrajové prípady a odštartujte cyklus so správne inicializovanými
 premennými.
</p>
</div>
<div class="editbuttontd">
<form action="#id0C----" method="POST" id="id0C----__" onsubmit="return submitForm(this,this);"
><a name="id0C----"/><input type="hidden" name="selector" value="id0C----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id1C----" class="editable"><a name="id3C----"/>
<form action="#id3C----" method="POST" id="id3C----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id3C----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id4C----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F1_efficient</mi>
</math></span> displayed by&nbsp;<em>Tex1_f1_efficient</em> as&nbsp;<math xmlns="&mathml;"
>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow><mo>(</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>)</mo>
</mrow>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#id4C----" method="POST" id="id4C----__" onsubmit="return submitForm(this,this);"
><a name="id4C----"/><input type="hidden" name="selector" value="id4C----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id5C----" class="editable"><a name="id7C----"/>
<form action="#id7C----" method="POST" id="id7C----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id7C----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id8C----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F1_efficient_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">F1_efficient_test</mi><mo>=</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">8</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">1</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">9</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#id8C----" method="POST" id="id8C----__" onsubmit="return submitForm(this,this);"
><a name="id8C----"/><input type="hidden" name="selector" value="id8C----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id9C----" class="editable"><a name="id-D----"/>
<form action="#id-D----" method="POST" id="id-D----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id-D----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idAD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F1_efficient_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">F1_efficient_result</mi><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">8</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">9</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idAD----" method="POST" id="idAD----__" onsubmit="return submitForm(this,this);"
><a name="idAD----"/><input type="hidden" name="selector" value="idAD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idBD----" class="editable"><a name="idDD----"/>
<form action="#idDD----" method="POST" id="idDD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idDD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idED----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>7.3 Simulácia for cyklu</b>
</p>
</div>
<div class="editbuttontd">
<form action="#idED----" method="POST" id="idED----__" onsubmit="return submitForm(this,this);"
><a name="idED----"/><input type="hidden" name="selector" value="idED----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idFD----" class="editable"><a name="idHD----"/>
<form action="#idHD----" method="POST" id="idHD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idHD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idID----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><i>Faktoriál simuláciou for cyklu.</i> Faktoriál môžeme počítať aj
 pomocou pascalovského for cyklu:
</p><pre>    f := 1;                       } Fact1
    for i := 1 to n do begin     -
        f := f*i                  |_ For_fact
    end;                          |
    Result := f                  -</pre>
</div>
<div class="editbuttontd">
<form action="#idID----" method="POST" id="idID----__" onsubmit="return submitForm(this,this);"
><a name="idID----"/><input type="hidden" name="selector" value="idID----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idJD----" class="editable"><a name="idLD----"/>
<form action="#idLD----" method="POST" id="idLD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idLD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idMD----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha. Faktoriál simuláciou for cyklu.</b> Naprogramujte funkciu <math
 xmlns="&mathml;">
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
</math> využitím pomocnej funkcie <math xmlns="&mathml;">
<mi class="ident">For_fact</mi>
</math>.
</p>
<p><b>a)</b> Funkcia <math xmlns="&mathml;">
<mi class="ident">For_fact</mi>
</math> simuluje for cyklus z predchádzajúcej poznámky. Zadefinujte ju <i
>spätnou rekuziou</i>, pri ktorej rekurzívny argument <math xmlns="&mathml;"
>
<mi>i</mi>
</math> rastie, kým neprekročí hranicu <math xmlns="&mathml;">
<mi>n</mi>
</math>. Uvedomte si, že cyklus
</p><pre>    for i := 1 to n do begin TELO end</pre>
<p>je ekvivalentný
</p><pre>    i := 1; while i &lt;= n do begin TELO; i := i+1 end</pre>
</div>
<div class="editbuttontd">
<form action="#idMD----" method="POST" id="idMD----__" onsubmit="return submitForm(this,this);"
><a name="idMD----"/><input type="hidden" name="selector" value="idMD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idND----" class="editable"><a name="idPD----"/>
<form action="#idPD----" method="POST" id="idPD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idPD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idQD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">For_fact</mi>
</math></span>&nbsp;/&nbsp;3</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">For_fact</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>i</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>f</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idQD----" method="POST" id="idQD----__" onsubmit="return submitForm(this,this);"
><a name="idQD----"/><input type="hidden" name="selector" value="idQD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idRD----" class="editable"><a name="idTD----"/>
<form action="#idTD----" method="POST" id="idTD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idTD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idUD----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>b)</b> Funkcia <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
</math> spustí cyklus so správne inicializovanými premennými <math xmlns="&mathml;"
>
<mi>i</mi>
</math>, <math xmlns="&mathml;">
<mi>f</mi>
</math> a <math xmlns="&mathml;">
<mi>n</mi>
</math>.
</p>
</div>
<div class="editbuttontd">
<form action="#idUD----" method="POST" id="idUD----__" onsubmit="return submitForm(this,this);"
><a name="idUD----"/><input type="hidden" name="selector" value="idUD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idVD----" class="editable"><a name="idXD----"/>
<form action="#idXD----" method="POST" id="idXD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idXD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idYD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">Fact</mi><mn class="id_sub">1</mn
>
</msub>
</math></span></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idYD----" method="POST" id="idYD----__" onsubmit="return submitForm(this,this);"
><a name="idYD----"/><input type="hidden" name="selector" value="idYD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idZD----" class="editable"><a name="idbD----"/>
<form action="#idbD----" method="POST" id="idbD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idbD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idcD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fact1_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Fact1_test</mi><mo>=</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">Fact</mi><mn class="id_sub">1</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idcD----" method="POST" id="idcD----__" onsubmit="return submitForm(this,this);"
><a name="idcD----"/><input type="hidden" name="selector" value="idcD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="iddD----" class="editable"><a name="idfD----"/>
<form action="#idfD----" method="POST" id="idfD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idfD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idgD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Fact1_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Fact1_result</mi><mo>=</mo><mn class="builtin">1</mn><mo class="builtin"
>,</mo><mn class="builtin">1</mn><mo class="builtin">,</mo><mn class="builtin"
>2</mn><mo class="builtin">,</mo><mn class="builtin">6</mn><mo class="builtin"
>,</mo><mn class="builtin">24</mn><mo class="builtin">,</mo><mn class="builtin"
>120</mn><mo class="builtin">,</mo><mn class="builtin">720</mn><mo class="builtin"
>,</mo><mn class="builtin">5040</mn><mo class="builtin">,</mo><mn class="builtin"
>0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idgD----" method="POST" id="idgD----__" onsubmit="return submitForm(this,this);"
><a name="idgD----"/><input type="hidden" name="selector" value="idgD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idhD----" class="editable"><a name="idjD----"/>
<form action="#idjD----" method="POST" id="idjD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idjD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idkD----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><math xmlns="&mathml;">
<mo>&ast;</mo>
</math> Úloha.</b> Zadefinujte efektívnu verziu <math xmlns="&mathml;">
<mi class="ident">F2_efficient</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> nasledujúcej funkcie <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> simuláciou for cyklu.
</p>
</div>
<div class="editbuttontd">
<form action="#idkD----" method="POST" id="idkD----__" onsubmit="return submitForm(this,this);"
><a name="idkD----"/><input type="hidden" name="selector" value="idkD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idlD----" class="editable"><a name="idnD----"/>
<form action="#idnD----" method="POST" id="idnD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idnD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idoD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">F</mi><mn class="id_sub">2</mn
>
</msub>
</math></span></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo class="builtin">+</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo class="builtin">+</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo class="builtin">+</mo><mi>n</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idoD----" method="POST" id="idoD----__" onsubmit="return submitForm(this,this);"
><a name="idoD----"/><input type="hidden" name="selector" value="idoD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idpD----" class="editable"><a name="idrD----"/>
<form action="#idrD----" method="POST" id="idrD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idrD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idsD----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p>Funkciu <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
</math> môžeme efektívne vypočítať nasledujúcim for cyklom.
</p><pre>    if n = 0 then                          -
        Result := 0                         |
    else if n = 1 then                      |
        Result := 1                         |_ F2_efficient
    else begin                              |
        n := n - 2; { ! }                   |
        a := 0; { F2(0) }                   |
        b := 1; { F2(1) }                  -
        for i := 0 to n do begin           -
            { a = F2(i) &amp; b = F2(i+1) }     |
            a1 := b;                        |
            b1 := a+b+i;                    |_ For_f2
            a := a1; b := b1;               |
            { a = F2(i+1) &amp; c = F2(i+2) }   |
        end;                                |
        Result := b                        -
    end</pre>
<p>Simulujte for cyklus pomocnou chvostovorekurzívnou funkciou <math xmlns="&mathml;"
>
<msub class="ident"><mi class="ident">For_f</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>i</mi><mo>,</mo><mi>n</mi><mo>,</mo><mi>a</mi
><mo>,</mo><mi>b</mi><mo>)</mo>
</mrow>
</math>.
</p>
<p>Invariant:
</p>
<math xmlns="&mathml;" mode="display">
<mi>i</mi><mo class="builtin">&lE;</mo><mi>n</mi><mo class="builtin">+</mo><mn
 class="builtin">1</mn><mo>&rarr;</mo>
<msub class="ident"><mi class="ident">For_f</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>i</mi><mo>,</mo><mi>n</mi><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo>)</mo>
</mrow><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>2</mn><mo>)</mo>
</mrow>
</math>
<p>Úvodné testy, inicializáciu premenných a štart cyklu implementujte 
v hlavnej funkcii <math xmlns="&mathml;">
<mi class="ident">F2_efficient</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math>
</p>
</div>
<div class="editbuttontd">
<form action="#idsD----" method="POST" id="idsD----__" onsubmit="return submitForm(this,this);"
><a name="idsD----"/><input type="hidden" name="selector" value="idsD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idtD----" class="editable"><a name="idvD----"/>
<form action="#idvD----" method="POST" id="idvD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idvD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idwD----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">For_f</mi><mn class="id_sub"
>2</mn>
</msub>
</math></span>&nbsp;/&nbsp;4</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">For_f</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>i</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>b</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idwD----" method="POST" id="idwD----__" onsubmit="return submitForm(this,this);"
><a name="idwD----"/><input type="hidden" name="selector" value="idwD----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idxD----" class="editable"><a name="idzD----"/>
<form action="#idzD----" method="POST" id="idzD----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idzD----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id0D----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F2_efficient</mi>
</math></span> displayed by&nbsp;<em>Tex1_f2_efficient</em> as&nbsp;<math xmlns="&mathml;"
>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow><mo>(</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>)</mo>
</mrow>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#id0D----" method="POST" id="id0D----__" onsubmit="return submitForm(this,this);"
><a name="id0D----"/><input type="hidden" name="selector" value="id0D----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id1D----" class="editable"><a name="id3D----"/>
<form action="#id3D----" method="POST" id="id3D----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id3D----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id4D----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F2_efficient_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">F2_efficient_test</mi><mo>=</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">8</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">2</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">9</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#id4D----" method="POST" id="id4D----__" onsubmit="return submitForm(this,this);"
><a name="id4D----"/><input type="hidden" name="selector" value="id4D----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id5D----" class="editable"><a name="id7D----"/>
<form action="#id7D----" method="POST" id="id7D----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id7D----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="id8D----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F2_efficient_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">F2_efficient_result</mi><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">8</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">2</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">9</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#id8D----" method="POST" id="id8D----__" onsubmit="return submitForm(this,this);"
><a name="id8D----"/><input type="hidden" name="selector" value="id8D----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="id9D----" class="editable"><a name="id-E----"/>
<form action="#id-E----" method="POST" id="id-E----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="id-E----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idAE----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><math xmlns="&mathml;">
<mo>&ast;</mo>
</math> Úloha.</b> Zadefinujte efektívnu verziu <math xmlns="&mathml;">
<mi class="ident">F3_efficient</mi>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo>&equiv;</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> funkcie <math xmlns="&mathml;">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow>
</math> simuláciou for cyklu podobne ako v predchádzajúcej úlohe.
</p>
</div>
<div class="editbuttontd">
<form action="#idAE----" method="POST" id="idAE----__" onsubmit="return submitForm(this,this);"
><a name="idAE----"/><input type="hidden" name="selector" value="idAE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idBE----" class="editable"><a name="idDE----"/>
<form action="#idDE----" method="POST" id="idDE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idDE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idEE----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">F</mi><mn class="id_sub">3</mn
>
</msub>
</math></span></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">2</mn>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo class="builtin">+</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo>)</mo>
</mrow><mo class="builtin">+</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo class="builtin">+</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>2</mn><mo>)</mo>
</mrow><mo class="builtin">+</mo><mi>n</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idEE----" method="POST" id="idEE----__" onsubmit="return submitForm(this,this);"
><a name="idEE----"/><input type="hidden" name="selector" value="idEE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idFE----" class="editable"><a name="idHE----"/>
<form action="#idHE----" method="POST" id="idHE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idHE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idIE----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p>Invariant:
</p>
<math xmlns="&mathml;" mode="display">
<mi>i</mi><mo class="builtin">&lE;</mo><mi>n</mi><mo class="builtin">+</mo><mn
 class="builtin">1</mn><mo>&rarr;</mo>
<msub class="ident"><mi class="ident">For_f</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>i</mi><mo>,</mo><mi>n</mi><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo>)</mo>
</mrow><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo class="builtin">+</mo><mn class="builtin"
>1</mn><mo>)</mo>
</mrow><mo>,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp2"><mo>(</mo><mi>i</mi><mo class="builtin">+</mo><mn class="builtin"
>2</mn><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mi>n</mi><mo class="builtin">+</mo><mn class="builtin"
>3</mn><mo>)</mo>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idIE----" method="POST" id="idIE----__" onsubmit="return submitForm(this,this);"
><a name="idIE----"/><input type="hidden" name="selector" value="idIE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idJE----" class="editable"><a name="idLE----"/>
<form action="#idLE----" method="POST" id="idLE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idLE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idME----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<msub class="inh_col_id"><mi class="inh_col_id">For_f</mi><mn class="id_sub"
>3</mn>
</msub>
</math></span>&nbsp;/&nbsp;5</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">For_f</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>i</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>b</mi>
</mstyle><mo>,</mo>
<mstyle class="bvar"><mi>c</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idME----" method="POST" id="idME----__" onsubmit="return submitForm(this,this);"
><a name="idME----"/><input type="hidden" name="selector" value="idME----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idNE----" class="editable"><a name="idPE----"/>
<form action="#idPE----" method="POST" id="idPE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idPE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idQE----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F3_efficient</mi>
</math></span> displayed by&nbsp;<em>Tex1_f3_efficient</em> as&nbsp;<math xmlns="&mathml;"
>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow><mo>(</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>)</mo>
</mrow>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>n</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#idQE----" method="POST" id="idQE----__" onsubmit="return submitForm(this,this);"
><a name="idQE----"/><input type="hidden" name="selector" value="idQE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idRE----" class="editable"><a name="idTE----"/>
<form action="#idTE----" method="POST" id="idTE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idTE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idUE----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F3_efficient_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">F3_efficient_test</mi><mo>=</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">8</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msubsup><mi mathvariant="normal">F</mi><mi mathvariant="normal">3</mi><mi mathvariant="normal"
>efficient</mi>
</msubsup>
<mrow class="cp1"><mo>(</mo><mn class="builtin">9</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idUE----" method="POST" id="idUE----__" onsubmit="return submitForm(this,this);"
><a name="idUE----"/><input type="hidden" name="selector" value="idUE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idVE----" class="editable"><a name="idXE----"/>
<form action="#idXE----" method="POST" id="idXE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idXE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idYE----" class="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">F3_efficient_result</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">F3_efficient_result</mi><mo>=</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">2</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">3</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">4</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">5</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">6</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">7</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">8</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<msub class="ident"><mi class="ident">F</mi><mn class="id_sub">3</mn>
</msub>
<mrow class="cp1"><mo>(</mo><mn class="builtin">9</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#idYE----" method="POST" id="idYE----__" onsubmit="return submitForm(this,this);"
><a name="idYE----"/><input type="hidden" name="selector" value="idYE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="idZE----" class="editable"><a name="idbE----"/>
<form action="#idbE----" method="POST" id="idbE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idbE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Ins/Del" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
<div><input type="submit" name="char" value="Expand" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
<div id="idcE----" class="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Prémiová domáca úloha <i>du03b</i>.</b> (2 body) Pravidlá pre prémiové
 domáce úlohy nájdete na <i>http://dai.fmph.uniba.sk/courses/udp#pdu</i>
</p>
<p class="indented">Zistite presný počet rekurzívnych volaní potrebných
 na výpočet <math xmlns="&mathml;">
<msub><mi mathvariant="normal">fib</mi><mn class="builtin">200</mn>
</msub>
</math> podľa klasickej <i>neefektívnej</i> definície (viď vyššie úvod
 k časti 7.2). Vysvetlite, ako ste k tomuto počtu dospeli.
</p>
<p class="indented"><i>[CL] Poznámka.</i> Pri výpočte odpovede pomocou CL
 narazíte na nasledovný problém: Hľadaný počet rekurzívnych volaní je
 viac ako 30-bitové číslo. Takéto čísla CL normálne zobrazuje v zmiešanom
 desiatkovo-dyadickom zápise (vysvetlíme neskôr). V iba desiatkovej sústave
 číslo zobrazíte použitím formátu <math xmlns="&mathml;">
<mi class="ident">N</mi>
</math> podľa nasledujúceho príkladu:
</p><pre>    123456789*1000000001 = x:N</pre>
</div>
<div class="editbuttontd">
<form action="#idcE----" method="POST" id="idcE----__" onsubmit="return submitForm(this,this);"
><a name="idcE----"/><input type="hidden" name="selector" value="idcE----"/><input
 type="submit" name="action" value="Edit" class="editbutton" onclick="return submitForm(this.form,this);"
/><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
</div>
</div>
</div>
<div id="iddE----" class="editable"><a name="ideE----"/>
<form action="#ideE----" method="POST" id="ideE----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="ideE----"/>
<div class="separatorbutton fill">
<div><pre><span class="fg3"></span></pre>
</div>
<div class="fill">
<hr/>
</div>
<div><input type="submit" name="char" value="Insert" class="button" onclick="return submitForm(this.form,this);"
/>
</div>
</div>
</form>
</div>
</div>
<div class="namedseparator fill">
<div>
<div class="vert_sep_name">Query:
</div>
<div class="fill">
<hr/>
</div>
</div>
</div>
<form action="#idgE----" method="POST" id="idgE----" onsubmit="return submitForm(this,this);"
><a name="idgE----"/><input type="hidden" name="selector" value="idgE----"/>
<div class="fieldwithbuttons editable fill">
<div class="fill"><textarea name="data" cols="78" rows="3">0 = x

</textarea>
</div>
<div class="editbuttontd"><input type="submit" name="action" value="OK" class="editbutton"
 onclick="return submitForm(this.form,this);"/><br/><input type="submit" name="action"
 value="Cancel" class="editbutton" onclick="return submitForm(this.form,this);"
/>
</div>
</div><input type="hidden" name="xoff" value="0"/><input type="hidden" name="yoff"
 value="0"/>
</form>
<div class="namedseparator fill">
<div>
<div class="vert_sep_name">Results:
</div>
<div class="fill">
<hr/>
</div>
</div>
</div>
<div id="idhE----" class="fill"><a name="idhE----"/>
<div>Heap used:&nbsp;388384 free:&nbsp;133827440
</div>
<div>Time used:&nbsp;0:0:0:44
</div>
</div>
</div>
</div>
</body></html>