<?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.20, 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.20, 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">Ex08b</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>8. CVIČENIE Z PREDMETU ÚVOD DO DEKLARATÍVNEHO PROGRAMOVANIA LS 2013/2014</b
>
</p>
<p><b>ČASŤ B</b>
</p>
<p>http://dai.fmph.uniba.sk/courses/udp/ex/ex08.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> 8. a 9. 4. 2014
</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é binárnym stromom (ex08a)
 a binárnym vyhľadávacím stromom (ex08b).
</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 2013/2014.
</p>
<p class="indented">http://dai.fmph.uniba.sk/courses/udp/udp-prednasky-2014.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">Included module&nbsp;<math
 xmlns="&mathml;">
<msub class="comp_id_hdr"><mi class="comp_id_hdr">Maux</mi><mn class="id_sub"
>08</mn>
</msub>
</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="fill"><a name="idw-----"/><span class="header">Included module&nbsp;<math
 xmlns="&mathml;">
<msub class="comp_id_hdr"><mi class="comp_id_hdr">Mtesting</mi><mn class="id_sub"
>08</mn>
</msub>
</math></span>
</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="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">E</mi>
</math></acronym>&nbsp;/&nbsp;0 displayed by&nbsp;<em>Tex0_e</em> as&nbsp;<math
 xmlns="&mathml;">
<mo>&bull;</mo>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mo>&bull;</mo><mo>=</mo><mn class="builtin">0</mn><mo class="builtin">,</mo
><mn class="builtin">0</mn>
</math>
</div>
<div class="editbuttontd">
<form action="#id0-----" method="POST" id="id0-----__" onsubmit="return submitForm(this,this);"
><a name="id0-----"/><input type="hidden" name="selector" value="id0-----"/><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="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="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">Nd</mi>
</math></acronym>&nbsp;/&nbsp;3 displayed by&nbsp;<em>Tex3_nd</em> as&nbsp;<math
 xmlns="&mathml;">
<mfrac>
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<mrow>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle><mo>&mid;</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>3</mn>
</msub>
</mstyle>
</mrow>
</mfrac>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mfrac>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow>
<mstyle class="bvar"><mi>l</mi>
</mstyle><mo>&mid;</mo>
<mstyle class="bvar"><mi>r</mi>
</mstyle>
</mrow>
</mfrac><mo>=</mo><mn class="builtin">1</mn><mo class="builtin">,</mo><mi>x</mi
><mo class="builtin">,</mo><mi>l</mi><mo class="builtin">,</mo><mi>r</mi>
</math>
</div>
<div class="editbuttontd">
<form action="#id4-----" method="POST" id="id4-----__" onsubmit="return submitForm(this,this);"
><a name="id4-----"/><input type="hidden" name="selector" value="id4-----"/><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="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="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Predicate&nbsp;<acronym title="This predicate is a format"
 class="pred_format"><math xmlns="&mathml;">
<mi class="inh_col_id">Bt</mi>
</math></acronym></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Bt</mi>
<mrow class="cp1"><mo>(</mo><mo>&bull;</mo><mo>)</mo>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Bt</mi>
<mrow class="cp1"><mo>(</mo>
<mfrac>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow>
<mstyle class="bvar"><mi>l</mi>
</mstyle><mo>&mid;</mo>
<mstyle class="bvar"><mi>r</mi>
</mstyle>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo>&larr;</mo>
<mrow><mi class="ident">N</mi>
<mrow class="cp1"><mo>(</mo><mi>x</mi><mo>)</mo>
</mrow>
</mrow><mo>&and;</mo>
<mrow><mi class="ident">Bt</mi>
<mrow class="cp1"><mo>(</mo><mi>l</mi><mo>)</mo>
</mrow>
</mrow><mo>&and;</mo>
<mrow><mi class="ident">Bt</mi>
<mrow class="cp1"><mo>(</mo><mi>r</mi><mo>)</mo>
</mrow>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#id8-----" method="POST" id="id8-----__" onsubmit="return submitForm(this,this);"
><a name="id8-----"/><input type="hidden" name="selector" value="id8-----"/><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="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="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Predicate&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Inbt</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_inbt</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub>
<mfrac>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow>
<mstyle class="bvar"><mi>l</mi>
</mstyle><mo>&mid;</mo>
<mstyle class="bvar"><mi>r</mi>
</mstyle>
</mrow>
</mfrac><mo>&larr;</mo>
<mrow><mi>a</mi><mo>=</mo><mi>x</mi>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub>
<mfrac>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow>
<mstyle class="bvar"><mi>l</mi>
</mstyle><mo>&mid;</mo>
<mstyle class="bvar"><mi>r</mi>
</mstyle>
</mrow>
</mfrac><mo>&larr;</mo>
<mrow><mi>a</mi><mo>&ne;</mo><mi>x</mi>
</mrow><mo>&and;</mo>
<mrow><mi>a</mi>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub><mi>l</mi>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub>
<mfrac>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow>
<mstyle class="bvar"><mi>l</mi>
</mstyle><mo>&mid;</mo>
<mstyle class="bvar"><mi>r</mi>
</mstyle>
</mrow>
</mfrac><mo>&larr;</mo>
<mrow><mi>a</mi><mo>&ne;</mo><mi>x</mi>
</mrow><mo>&and;</mo>
<mrow><mo>&not;</mo><mi>a</mi>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub><mi>l</mi>
</mrow><mo>&and;</mo>
<mrow><mi>a</mi>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub><mi>r</mi>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idAA----" method="POST" id="idAA----__" onsubmit="return submitForm(this,this);"
><a name="idAA----"/><input type="hidden" name="selector" value="idAA----"/><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="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="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="#idEA----" method="POST" id="idEA----__" onsubmit="return submitForm(this,this);"
><a name="idEA----"/><input type="hidden" name="selector" value="idEA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>15.4. Binárne vyhľadávacie stromy</b>
</p>
</div>
<div class="editbuttontd">
<form action="#idIA----" method="POST" id="idIA----__" onsubmit="return submitForm(this,this);"
><a name="idIA----"/><input type="hidden" name="selector" value="idIA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><i>Definícia.</i></b> Binárny strom <math xmlns="&mathml;">
<mi>t</mi>
</math> je <i>vyhľadávací</i>, ak pre každý jeho podstrom <math xmlns="&mathml;"
>
<mfrac><mi>x</mi>
<mrow><mi>l</mi><mo>&mid;</mo><mi>r</mi>
</mrow>
</mfrac>
</math> platí, že prvky nachádzajúce sa v ľavom dieťati <math xmlns="&mathml;"
>
<mi>l</mi>
</math> sú menšie ako <math xmlns="&mathml;">
<mi>x</mi>
</math> a prvky nachádzajúce sa v pravom dieťati <math xmlns="&mathml;"
>
<mi>r</mi>
</math> sú väčšie ako <math xmlns="&mathml;">
<mi>x</mi>
</math>.
</p>
<p class="indented">Vlastnosť „ <math xmlns="&mathml;">
<mi>t</mi>
</math> je binárnym vyhľadávacím stromom“ budeme označovať predikátom
 <math xmlns="&mathml;">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</math>. Výsledkom nasledujúcich dvoch úloh je rekurzívna definícia tohto
 predikátu.
</p>
</div>
<div class="editbuttontd">
<form action="#idMA----" method="POST" id="idMA----__" onsubmit="return submitForm(this,this);"
><a name="idMA----"/><input type="hidden" name="selector" value="idMA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><i>Príklad.</i></b> Nasledujúci binárny strom <math xmlns="&mathml;"
>
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub>
</math> je vyhľadávací.
</p>
</div>
<div class="editbuttontd">
<form action="#idQA----" method="POST" id="idQA----__" onsubmit="return submitForm(this,this);"
><a name="idQA----"/><input type="hidden" name="selector" value="idQA----"/><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="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="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">T</mi><mn class="id_sub">1</mn
>
</msub>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub><mo>=</mo>
<mfrac><mn class="builtin">12</mn>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">4</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">20</mn>
<mrow>
<mfrac><mn class="builtin">15</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">25</mn>
<mrow>
<mfrac><mn class="builtin">22</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac>
</math>
</div>
<div class="editbuttontd">
<form action="#idUA----" method="POST" id="idUA----__" onsubmit="return submitForm(this,this);"
><a name="idUA----"/><input type="hidden" name="selector" value="idUA----"/><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="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="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.</b> Rekurziou na binárnych stromoch zadefinujte predikáty <math
 xmlns="&mathml;">
<mi class="ident">Lt</mi>
<mrow class="cp1"><mo>(</mo><mi>a</mi><mo>,</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>a</mi><mo>&pr;</mo><mi>t</mi>
</math> a <math xmlns="&mathml;">
<mi class="ident">Gt</mi>
<mrow class="cp1"><mo>(</mo><mi>a</mi><mo>,</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>a</mi><mo>&sc;</mo><mi>t</mi>
</math>. Predikát <math xmlns="&mathml;">
<mi>a</mi><mo>&pr;</mo><mi>t</mi>
</math> platí, ak <math xmlns="&mathml;">
<mi>a</mi>
</math> je menšie ako všetky hodnoty uložené v strome <math xmlns="&mathml;"
>
<mi>t</mi>
</math>. Predikát <math xmlns="&mathml;">
<mi>a</mi><mo>&sc;</mo><mi>t</mi>
</math> platí, ak <math xmlns="&mathml;">
<mi>a</mi>
</math> je väčšie ako všetky hodnoty uložené v strome <math xmlns="&mathml;"
>
<mi>t</mi>
</math>.
</p>
<p class="indented">Špecifikácia:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bt</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi>a</mi><mo>&pr;</mo><mi>t</mi><mo>&harr;</mo>
<mrow><mo>&forall;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub><mi>t</mi><mo>&rarr;</mo><mi>a</mi><mo class="builtin">&lt;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo>)</mo>
</mrow>
</mrow>
</math>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bt</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi>a</mi><mo>&sc;</mo><mi>t</mi><mo>&harr;</mo>
<mrow><mo>&forall;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub><mi>t</mi><mo>&rarr;</mo><mi>a</mi><mo class="builtin">&gt;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo>)</mo>
</mrow>
</mrow>
</math>
<p>Testovanie:
</p><pre>    Lt_test = r:Results
    Gt_test = r:Results</pre>
</div>
<div class="editbuttontd">
<form action="#idYA----" method="POST" id="idYA----__" onsubmit="return submitForm(this,this);"
><a name="idYA----"/><input type="hidden" name="selector" value="idYA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Predicate&nbsp;<acronym title="This is an inductive predicate"
 class="pred_induct"><math xmlns="&mathml;">
<mi class="inh_col_id">Lt</mi>
</math></acronym>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_lt</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>&pr;</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>&pr;</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&larr;</mo>
<mrow><mi class="adident">?</mi>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idcA----" method="POST" id="idcA----__" onsubmit="return submitForm(this,this);"
><a name="idcA----"/><input type="hidden" name="selector" value="idcA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Predicate&nbsp;<acronym title="This is an inductive predicate"
 class="pred_induct"><math xmlns="&mathml;">
<mi class="inh_col_id">Gt</mi>
</math></acronym>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_gt</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>&sc;</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>&sc;</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&larr;</mo>
<mrow><mi class="adident">?</mi>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idgA----" method="POST" id="idgA----__" onsubmit="return submitForm(this,this);"
><a name="idgA----"/><input type="hidden" name="selector" value="idgA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Lt_</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_lt_</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow><mo>&not;</mo><mi>a</mi><mo>&pr;</mo><mi>t</mi>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn><mo>&larr;</mo>
<mrow><mi>a</mi><mo>&pr;</mo><mi>t</mi>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idkA----" method="POST" id="idkA----__" onsubmit="return submitForm(this,this);"
><a name="idkA----"/><input type="hidden" name="selector" value="idkA----"/><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="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="fieldwithbuttons editable fill">
<div class="fill"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Gt_</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_gt_</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow><mo>&not;</mo><mi>a</mi><mo>&sc;</mo><mi>t</mi>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn><mo>&larr;</mo>
<mrow><mi>a</mi><mo>&sc;</mo><mi>t</mi>
</mrow>
</math>
</div>
<div class="editbuttontd">
<form action="#idoA----" method="POST" id="idoA----__" onsubmit="return submitForm(this,this);"
><a name="idoA----"/><input type="hidden" name="selector" value="idoA----"/><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="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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Lt_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Lt_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">1</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">3</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">1</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">2</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">3</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">4</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&pr;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>3</mn>
</msub>
</mstyle>
</mrow><mo>&and;</mo>
<mrow>
<mfrac><mn class="builtin">4</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>4</mn>
</msub>
</mstyle>
</mrow>
</math>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Gt_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Gt_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">1</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">3</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">2</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">4</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn>
<msub><mo>&sc;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>4</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>3</mn>
</msub>
</mstyle>
</mrow><mo>&and;</mo>
<mrow>
<mfrac><mn class="builtin">1</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow>
<mfrac><mn class="builtin">4</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>4</mn>
</msub>
</mstyle>
</mrow>
</math>
</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><b>Úloha.</b> Zadefinujte predikát <math xmlns="&mathml;">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</math>, ktorý platí, keď <math xmlns="&mathml;">
<mi>t</mi>
</math> je binárnym vyhľadávacím stromom. Predikát pomocou rekurzie na 
binárnych stromoch overí vyhľadávaciu vlastnosť v každom podstrome stromu
 <math xmlns="&mathml;">
<mi>t</mi>
</math>. Použite predikáty <math xmlns="&mathml;">
<mi>a</mi><mo>&pr;</mo><mi>t</mi>
</math> a <math xmlns="&mathml;">
<mi>a</mi><mo>&sc;</mo><mi>t</mi>
</math> z predchádzajúcej úlohy.
</p>
<p class="indented">Pozitívne príklady: <math xmlns="&mathml;">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mo>&bull;</mo><mo>)</mo>
</mrow>
</math>, <math xmlns="&mathml;">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
</math>, <math xmlns="&mathml;">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo>
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub><mo>)</mo>
</mrow>
</math>.
</p>
<p class="indented">Negatívne príklady: <math xmlns="&mathml;">
<mo>&not;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">4</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
</math>, <math xmlns="&mathml;">
<mo>&not;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">8</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
</math>.
</p>
<p>Testovanie:
</p><pre>    Bst_test = r:Results</pre>
</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"><span class="header">Predicate&nbsp;<acronym title="This is an inductive predicate"
 class="pred_induct"><math xmlns="&mathml;">
<mi class="inh_col_id">Bst</mi>
</math></acronym></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>&larr;</mo>
<mrow><mi class="adident">?</mi>
</mrow>
</math>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Bst_</mi>
</math></span></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Bst_</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow><mo>&not;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Bst_</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn><mo>&larr;</mo>
<mrow><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</mrow>
</math>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Bst_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Bst_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<msub><mi>t</mi><mn>2</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">3</mn>
<mrow>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow>
<msub><mi>t</mi><mn>2</mn>
</msub><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">8</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>&mid;</mo>
<mfrac><mn class="builtin">8</mn>
<mrow>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Bst_</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow>
<msub><mi>t</mi><mn>3</mn>
</msub><mo>&mid;</mo>
<mfrac><mn class="builtin">8</mn>
<mrow>
<mfrac><mn class="builtin">4</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>2</mn>
</msub>
</mstyle>
</mrow><mo>&and;</mo>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>3</mn>
</msub>
</mstyle>
</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">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha.</b> Zadefinujte predikát <math xmlns="&mathml;">
<mi class="ident">Inbst</mi>
<mrow class="cp1"><mo>(</mo><mi>a</mi><mo>,</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>a</mi><mo>&isin;</mo><mi>t</mi>
</math>, ktorý platí, ak <math xmlns="&mathml;">
<mi>a</mi>
</math> je hodnotou uloženou v binárnom vyhľadávacom strome.
</p>
<p class="indented">Napríklad <math xmlns="&mathml;">
<mn class="builtin">4</mn><mo>&isin;</mo>
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub>
</math> a <math xmlns="&mathml;">
<mo>&not;</mo><mn class="builtin">6</mn><mo>&isin;</mo>
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub>
</math>.
</p>
<p class="indented">Špecifikácia:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi>a</mi><mo>&isin;</mo><mi>t</mi><mo>&harr;</mo><mi>a</mi
>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub><mi>t</mi>
</math>
<p>Využite (ale netestujte ani nijak nezabezpečujte), že <math xmlns="&mathml;"
>
<mi>t</mi>
</math> je vyhľadávací strom. Pri vyhľadávaní prvku stačí prejsť jedinú
 cestu v strome, na ktorej sa môže nachádzať.
</p>
<p>Testovanie:
</p><pre>    Inbst_test = r:Results</pre>
</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">Predicate&nbsp;<acronym title="This is an inductive predicate"
 class="pred_induct"><math xmlns="&mathml;">
<mi class="inh_col_id">Inbst</mi>
</math></acronym>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_inbst</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>&isin;</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>&isin;</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&larr;</mo>
<mrow><mi class="adident">?</mi>
</mrow>
</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">Inbst_</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_inbst_</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow><mo>&not;</mo><mi>a</mi><mo>&isin;</mo><mi>t</mi>
</mrow>
</math>
<math xmlns="&mathml;" mode="display" class="clause">
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mn class="builtin">1</mn><mo>&larr;</mo>
<mrow><mi>a</mi><mo>&isin;</mo><mi>t</mi>
</mrow>
</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">Inbst_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Inbst_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub><mo>&bull;</mo><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<mfrac><mn class="builtin">7</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">2</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">5</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">8</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">9</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">1</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">0</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">4</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow class="cp2"><mo>(</mo><mn class="builtin">10</mn>
<msub><mo>&isin;</mo><mo>&ast;</mo>
</msub>
<msub><mi>t</mi><mn>6</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mn class="builtin">0</mn><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow>
<mfrac><mn class="builtin">6</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">8</mn>
<mrow>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>6</mn>
</msub>
</mstyle>
</mrow>
</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.</b> Zadefinujte funkciu <math xmlns="&mathml;">
<mi class="ident">Insert</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>,</mo><mi>a</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>t</mi><mo>&cup;</mo>
<mrow class="cp1"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow>
</math>, ktorá vloží hodnotu <math xmlns="&mathml;">
<mi>a</mi>
</math> do binárneho vyhľadávacieho stromu <math xmlns="&mathml;">
<mi>t</mi>
</math>.
</p>
<p class="indented">Špecifikácia: 
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow><mo>)</mo>
</mrow>
</math>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi>x</mi><mo>&isin;</mo><mi>t</mi><mo>&cup;</mo>
<mrow class="cp1"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow><mo>&harr;</mo><mi>x</mi><mo>=</mo><mi>a</mi><mo>&or;</mo><mi>x</mi><mo
>&isin;</mo><mi>t</mi>
</math>
<p>Nepoužite žiadne pomocné funkcie ani predikáty (ani <math xmlns="&mathml;"
>
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</math> a <math xmlns="&mathml;">
<mi>a</mi><mo>&isin;</mo><mi>t</mi>
</math>). Pri vynáraní z rekurzie je potrebné strom zrekonštruovať.
</p>
<p>Testovanie:
</p><pre>    Insert_test = r:Results_bt</pre>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Insert</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_insert</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>&cup;</mo>
<mrow><mo>{</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle><mo>}</mo>
</mrow>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&cup;</mo>
<mrow class="cp1"><mo>{</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>}</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Insert_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Insert_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<mrow><mo>&bull;</mo><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">5</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">6</mn>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">7</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msub><mi>t</mi><mn>60</mn>
</msub><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">80</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<msub><mi>t</mi><mn>60</mn>
</msub><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msub><mi>t</mi><mn>60</mn>
</msub><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">0</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">60</mn>
<mrow>
<mfrac><mn class="builtin">30</mn>
<mrow>
<mfrac><mn class="builtin">20</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">50</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">80</mn>
<mrow>
<mfrac><mn class="builtin">70</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">90</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msub><mi>t</mi><mn>60</mn>
</msub><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">75</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">60</mn>
<mrow>
<mfrac><mn class="builtin">30</mn>
<mrow>
<mfrac><mn class="builtin">20</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">50</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">80</mn>
<mrow>
<mfrac><mn class="builtin">70</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">75</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">90</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msub><mi>t</mi><mn>60</mn>
</msub><mo>&cup;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">100</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">60</mn>
<mrow>
<mfrac><mn class="builtin">30</mn>
<mrow>
<mfrac><mn class="builtin">20</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">50</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">80</mn>
<mrow>
<mfrac><mn class="builtin">70</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">90</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">100</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn><mo>&larr;</mo>
<mrow>
<mfrac><mn class="builtin">60</mn>
<mrow>
<mfrac><mn class="builtin">30</mn>
<mrow>
<mfrac><mn class="builtin">20</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">50</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">80</mn>
<mrow>
<mfrac><mn class="builtin">70</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">90</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>=</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>60</mn>
</msub>
</mstyle>
</mrow>
</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">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><i>Zmazanie prvku z binárneho vyhľadávacieho stromu.</i></b> Proces
 vymazávania hodnoty <math xmlns="&mathml;">
<mi>a</mi>
</math> z binárneho vyhľadávacieho stromu <math xmlns="&mathml;">
<mi>t</mi>
</math> sme opísali na prednáške. V nasledujúcich úlohách ho naprogramujeme
 ako rekurzívnu funkciu <math xmlns="&mathml;">
<mi class="ident">Delete</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>,</mo><mi>a</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>t</mi><mo>&setmn;</mo>
<mrow class="cp1"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow>
</math>. Použijeme pri tom dve pomocné funkcie:
</p>
<ul>
<li>
<p>Funkcia <math xmlns="&mathml;">
<mi class="ident">Extract_max</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</math> vyberie z binárneho vyhľadávacieho stromu jeho maximum.
</p>
</li>
<li>
<p>Funkcia <math xmlns="&mathml;">
<mi class="ident">Join</mi>
<mrow class="cp1"><mo>(</mo><mi>s</mi><mo>,</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>s</mi><mo>&sqcup;</mo><mi>t</mi>
</math> spojí stromy <math xmlns="&mathml;">
<mi>s</mi>
</math> a <math xmlns="&mathml;">
<mi>t</mi>
</math>, ktoré sú ľavým a pravým dieťaťom vymazávaného uzla, do nového
 binárneho vyhľadávacieho stromu.
</p>
</li>
</ul>
</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>Úloha.</b> Zadefinujte funkciu <math xmlns="&mathml;">
<mi class="ident">Extract_max</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow>
</math>, ktorá pre neprázdny binárny vyhľadávací strom <math xmlns="&mathml;"
>
<mi>t</mi>
</math> vráti dvojicu <math xmlns="&mathml;">
<mi>m</mi><mo class="builtin">,</mo>
<msub><mi>t</mi><mn>1</mn>
</msub>
</math>, kde
</p>
<ul>
<li>
<p><math xmlns="&mathml;">
<mi>m</mi>
</math> je maximálna hodnota uložená v strome <math xmlns="&mathml;">
<mi>t</mi>
</math>,
</p>
</li>
<li>
<p><math xmlns="&mathml;">
<msub><mi>t</mi><mn>1</mn>
</msub>
</math> je binárny vyhľadávací strom, ktorý obsahuje rovnaké hodnoty ako
 <math xmlns="&mathml;">
<mi>t</mi>
</math> okrem <math xmlns="&mathml;">
<mi>m</mi>
</math>.
</p>
</li>
</ul>
<p>Špecifikácia:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&and;</mo>
<mrow><mi>t</mi><mo>&ne;</mo><mo>&bull;</mo>
</mrow><mo>&rarr;</mo>
<mrow><mo>&exist;</mo>
<mstyle class="bvar"><mi>m</mi>
</mstyle>
<mrow><mo>&exist;</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>1</mn>
</msub>
</mstyle>
<mrow class="cp1"><mo>(</mo><mi class="ident">Extract_max</mi>
<mrow class="cp2"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>=</mo>
<mstyle class="bvar"><mi>m</mi>
</mstyle><mo class="builtin">,</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>1</mn>
</msub>
</mstyle><mo>&and;</mo>
<mstyle class="bvar"><mi>m</mi>
</mstyle><mo>&isin;</mo><mi>t</mi><mo>&and;</mo><mi class="ident">Bst</mi>
<mrow class="cp2"><mo>(</mo>
<mstyle class="bvar">
<msub><mi>t</mi><mn>1</mn>
</msub>
</mstyle><mo>)</mo>
</mrow><mo>)</mo>
</mrow>
</mrow>
</mrow>
</math>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&and;</mo><mi class="ident">Extract_max</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>=</mo><mi>m</mi><mo class="builtin">,</mo>
<msub><mi>t</mi><mn>1</mn>
</msub><mo>&and;</mo><mi>x</mi><mo>&isin;</mo><mi>t</mi><mo>&rarr;</mo><mi>x</mi
><mo class="builtin">&lE;</mo><mi>m</mi>
</math>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&and;</mo><mi class="ident">Extract_max</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>=</mo><mi>m</mi><mo class="builtin">,</mo>
<msub><mi>t</mi><mn>1</mn>
</msub><mo>&rarr;</mo><mi>x</mi><mo>&isin;</mo>
<msub><mi>t</mi><mn>1</mn>
</msub><mo>&harr;</mo><mi>x</mi><mo>&ne;</mo><mi>m</mi><mo>&and;</mo><mi>x</mi
><mo>&isin;</mo><mi>t</mi>
</math>
<p>Nepoužite žiadne pomocné funkcie. Výsledok rekurzívneho volania je pred
 použitím potrebné rozdeliť na zložky <math xmlns="&mathml;">
<mi>m</mi>
</math> a <math xmlns="&mathml;">
<msub><mi>t</mi><mn>1</mn>
</msub>
</math> podobne ako pri tuplingových funkciách v predchádzajúcich cvičeniach.
</p>
<p>Testovanie:
</p><pre>    Extract_max_test = r:Results_n_bt</pre>
</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">Extract_max</mi>
</math></span></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Extract_max</mi>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>)</mo>
</mrow><mo>=</mo><mi class="adident">?</mi><mo class="builtin">,</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">Extract_max_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Extract_max_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Extract_max</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mrow class="cp2"><mo>(</mo><mn class="builtin">6</mn><mo class="builtin">,</mo
><mo>&bull;</mo><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Extract_max</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">7</mn>
<mrow>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mrow class="cp2"><mo>(</mo><mn class="builtin">7</mn><mo class="builtin">,</mo
>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Extract_max</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mrow class="cp2"><mo>(</mo><mn class="builtin">2</mn><mo class="builtin">,</mo
>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Extract_max</mi>
<mrow class="cp2"><mo>(</mo>
<mfrac><mn class="builtin">5</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">8</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mrow class="cp2"><mo>(</mo><mn class="builtin">8</mn><mo class="builtin">,</mo
>
<mfrac><mn class="builtin">5</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo><mi class="ident">Extract_max</mi>
<mrow class="cp2"><mo>(</mo>
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub><mo>)</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mrow class="cp2"><mo>(</mo><mn class="builtin">25</mn><mo class="builtin">,</mo
>
<mfrac><mn class="builtin">12</mn>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">4</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">20</mn>
<mrow>
<mfrac><mn class="builtin">15</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">22</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><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">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b><i>Porovnanie všetkých hodnôt v dvoch binárnych stromoch.</i></b>
 Nasledujúci predikát platí, ak sú všetky hodnoty v binárnom strome <math
 xmlns="&mathml;">
<mi>s</mi>
</math> menšie ako všetky hodnoty v binárnom strome <math xmlns="&mathml;"
>
<mi>t</mi>
</math>. Definícia s kvantifikátormi sa nedá vyhodnotiť, predikát slúži
 iba na špecifikáciu nasledujúcej funkcie <math xmlns="&mathml;">
<mi class="ident">Join</mi>
</math>.
</p>
</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"><span class="header">Predicate&nbsp;<acronym title="This is a non-Sigma0 definition"
 class="fun_pred_nsgm0"><math xmlns="&mathml;">
<mi class="inh_col_id">Ltb</mi>
</math></acronym>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_ltb</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle>
<msub><mi mathvariant="normal">&pr;</mi><mi mathvariant="italic">b</mi>
</msub>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>s</mi>
</mstyle>
<msub><mi mathvariant="normal">&pr;</mi><mi mathvariant="italic">b</mi>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&harr;</mo>
<mrow><mo>&forall;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow><mo>&forall;</mo>
<mstyle class="bvar"><mi>y</mi>
</mstyle>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub>
<mstyle class="bvar"><mi>s</mi>
</mstyle><mo>&and;</mo>
<mstyle class="bvar"><mi>y</mi>
</mstyle>
<msub><mi mathvariant="normal">&epsiv;</mi><mi mathvariant="italic">b</mi>
</msub>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&rarr;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo class="builtin">&lt;</mo>
<mstyle class="bvar"><mi>y</mi>
</mstyle><mo>)</mo>
</mrow>
</mrow>
</mrow>
</math>
</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>Všimite si, že platí
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo>
<mfrac><mi>x</mi>
<mrow><mi>l</mi><mo>&mid;</mo><mi>r</mi>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo>&rarr;</mo><mi>l</mi>
<msub><mi mathvariant="normal">&pr;</mi><mi mathvariant="italic">b</mi>
</msub><mi>r</mi>
</math>
</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">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha.</b> Zadefinujte funkciu <math xmlns="&mathml;">
<mi class="ident">Join</mi>
<mrow class="cp1"><mo>(</mo><mi>s</mi><mo>,</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>s</mi><mo>&sqcup;</mo><mi>t</mi>
</math>, ktorá spojí dve bývalé deti uzla v binárnom vyhľadávacom strome
 do jedného binárneho vyhľadávacieho stromu.
</p>
<p class="indented">Ak sú <i>oba</i> stromy neprázdne, funkcia vytvorí nový
 strom využitím výsledkov funkcie <math xmlns="&mathml;">
<mi class="ident">Extract_max</mi>
</math>.
</p>
<p class="indented">Ak je <math xmlns="&mathml;">
<mi>s</mi>
</math> prázdny funkcia vráti <math xmlns="&mathml;">
<mi>t</mi>
</math>. Ak je <math xmlns="&mathml;">
<mi>s</mi>
</math> neprázdny a <math xmlns="&mathml;">
<mi>t</mi>
</math> prázdny, funkcia vráti <math xmlns="&mathml;">
<mi>s</mi>
</math>.
</p>
<p class="indented">Špecifikácia:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>s</mi><mo>)</mo>
</mrow><mo>&and;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&and;</mo><mi>s</mi>
<msub><mi mathvariant="normal">&pr;</mi><mi mathvariant="italic">b</mi>
</msub><mi>t</mi><mo>&rarr;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>s</mi><mo>&sqcup;</mo><mi>t</mi><mo>)</mo>
</mrow>
</math>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>s</mi><mo>)</mo>
</mrow><mo>&and;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&and;</mo><mi>s</mi>
<msub><mi mathvariant="normal">&pr;</mi><mi mathvariant="italic">b</mi>
</msub><mi>t</mi><mo>&rarr;</mo>
<mrow><mo>&forall;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle>
<mrow class="cp1"><mo>(</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo>&isin;</mo><mi>s</mi><mo>&sqcup;</mo><mi>t</mi><mo>&harr;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo>&isin;</mo><mi>s</mi><mo>&or;</mo>
<mstyle class="bvar"><mi>x</mi>
</mstyle><mo>&isin;</mo><mi>t</mi><mo>)</mo>
</mrow>
</mrow>
</math>
<p>Použite iba funkciu <math xmlns="&mathml;">
<mi class="ident">Extract_max</mi>
</math>. Nie je potrebná rekurzia.
</p>
<p>Testovanie:
</p><pre>    Join_test = r:Results_bt</pre>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Join</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_join</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>&sqcup;</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>s</mi>
</mstyle><mo>&sqcup;</mo>
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>=</mo><mi class="adident">?</mi>
</math>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Join_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Join_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<mrow><mo>&bull;</mo><mo>&sqcup;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&sqcup;</mo><mo>&bull;</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">4</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&sqcup;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">4</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">1</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">4</mn>
<mrow>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&sqcup;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">4</mn>
<mrow>
<mfrac><mn class="builtin">1</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</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">
<div class="header">Remark&nbsp;<math xmlns="&mathml;">
<mi class="comp_id_hdr"></mi>
</math>
</div>
<p><b>Úloha.</b> Zadefinujte funkciu <math xmlns="&mathml;">
<mi class="ident">Delete</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>,</mo><mi>a</mi><mo>)</mo>
</mrow><mo>&equiv;</mo><mi>t</mi><mo>&setmn;</mo>
<mrow class="cp1"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow>
</math>, ktorá zmaže hodnotu <math xmlns="&mathml;">
<mi>a</mi>
</math> z binárneho vyhľadávacieho stromu <math xmlns="&mathml;">
<mi>t</mi>
</math>.
</p>
<p class="indented">Špecifikácia:
</p>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow><mo>)</mo>
</mrow>
</math>
<math xmlns="&mathml;" mode="display">
<mi class="ident">Bst</mi>
<mrow class="cp1"><mo>(</mo><mi>t</mi><mo>)</mo>
</mrow><mo>&rarr;</mo><mi>x</mi><mo>&isin;</mo><mi>t</mi><mo>&setmn;</mo>
<mrow class="cp1"><mo>{</mo><mi>a</mi><mo>}</mo>
</mrow><mo>&harr;</mo><mi>x</mi><mo>&ne;</mo><mi>a</mi><mo>&and;</mo><mi>x</mi
><mo>&isin;</mo><mi>t</mi>
</math>
<p>Použite iba rekurziu a funkciu <math xmlns="&mathml;">
<mi>s</mi><mo>&sqcup;</mo><mi>t</mi>
</math>.
</p>
<p>Testovanie:
</p><pre>    Delete_test = r:Results_bt</pre>
</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"><span class="header">Function&nbsp;<span class="comp_id_hdr"
><math xmlns="&mathml;">
<mi class="inh_col_id">Delete</mi>
</math></span>&nbsp;/&nbsp;2 displayed by&nbsp;<em>Tex2_delete</em> as&nbsp;<math
 xmlns="&mathml;">
<mstyle class="bvar">
<msub><mi>#</mi><mn>1</mn>
</msub>
</mstyle><mo>&setmn;</mo>
<mrow><mo>{</mo>
<mstyle class="bvar">
<msub><mi>#</mi><mn>2</mn>
</msub>
</mstyle><mo>}</mo>
</mrow>
</math></span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mstyle class="bvar"><mi>t</mi>
</mstyle><mo>&setmn;</mo>
<mrow class="cp1"><mo>{</mo>
<mstyle class="bvar"><mi>a</mi>
</mstyle><mo>}</mo>
</mrow><mo>=</mo><mi class="adident">?</mi>
</math>
</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">Delete_test</mi>
</math></span>&nbsp;/&nbsp;0</span><br/>
<math xmlns="&mathml;" mode="display" class="clause">
<mi class="ident">Delete_test</mi><mo>=</mo>
<mrow class="cp1"><mo>(</mo>
<mrow><mo>&bull;</mo><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mo>&bull;</mo><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup><mo>&bull;</mo><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">2</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">7</mn>
<mrow>
<mfrac><mn class="builtin">6</mn>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">5</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">7</mn>
<mrow>
<mfrac><mn class="builtin">6</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">7</mn>
<mrow>
<mfrac><mn class="builtin">6</mn>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">6</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">7</mn>
<mrow>
<mfrac><mn class="builtin">5</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">3</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">2</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">2</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">1</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo>
<mrow class="cp1"><mo>(</mo>
<msub class="ident"><mi class="ident">T</mi><mn class="id_sub">1</mn>
</msub><mo>&setmn;</mo>
<mrow class="cp2"><mo>{</mo><mn class="builtin">5</mn><mo>}</mo>
</mrow>
<msup><mo>=</mo><mi mathvariant="bold-sans-serif">?</mi>
</msup>
<mfrac><mn class="builtin">12</mn>
<mrow>
<mfrac><mn class="builtin">4</mn>
<mrow>
<mfrac><mn class="builtin">2</mn>
<mrow>
<mfrac><mn class="builtin">0</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">3</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">7</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo>
<mfrac><mn class="builtin">9</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">20</mn>
<mrow>
<mfrac><mn class="builtin">15</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo>
<mfrac><mn class="builtin">25</mn>
<mrow>
<mfrac><mn class="builtin">22</mn>
<mrow><mo>&bull;</mo><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac><mo>&mid;</mo><mo>&bull;</mo>
</mrow>
</mfrac>
</mrow>
</mfrac>
</mrow>
</mfrac><mo>)</mo>
</mrow><mo class="builtin">,</mo><mn class="builtin">0</mn>
</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="idSC----"/>
<form action="#idSC----" method="POST" id="idSC----" onsubmit="return submitForm(this,this);"
><input type="hidden" name="action" value="button"/><input type="hidden" name="selector"
 value="idSC----"/>
<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="#idUC----" method="POST" id="idUC----" onsubmit="return submitForm(this,this);"
><a name="idUC----"/><input type="hidden" name="selector" value="idUC----"/>
<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="idVC----" class="fill"><a name="idVC----"/>
<div>Heap used:&nbsp;517100 free:&nbsp;133699540
</div>
<div>Time used:&nbsp;0:0:0:79
</div>
</div>
</div>
</div>
</body></html>