a00027.html 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
  5. <title>GTL - Graph Template Library: symlist&lt; T &gt; Class Template Reference</title>
  6. <link href="doxygen.css" rel="stylesheet" type="text/css">
  7. </head>
  8. <body>
  9. <p class="links">
  10. <a href="../index.html">Home</a> |
  11. Documentation |
  12. <a href="../register.html">Download</a> |
  13. <a href="../platforms.html">Platforms</a> |
  14. <a href="../refer.html">Projects</a> |
  15. <a href="../lists.html">Mailing Lists</a> |
  16. <a href="../history.html">Version History</a>
  17. </p>
  18. <!-- Generated by Doxygen 1.5.3 -->
  19. <div class="tabs">
  20. <ul>
  21. <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
  22. <li class="current"><a href="classes.html"><span>Classes</span></a></li>
  23. <li><a href="files.html"><span>Files</span></a></li>
  24. <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
  25. </ul>
  26. </div>
  27. <div class="tabs">
  28. <ul>
  29. <li><a href="classes.html"><span>Alphabetical&nbsp;List</span></a></li>
  30. <li><a href="annotated.html"><span>Class&nbsp;List</span></a></li>
  31. <li><a href="hierarchy.html"><span>Class&nbsp;Hierarchy</span></a></li>
  32. <li><a href="functions.html"><span>Class&nbsp;Members</span></a></li>
  33. </ul>
  34. </div>
  35. <h1>symlist&lt; T &gt; Class Template Reference</h1><!-- doxytag: class="symlist" -->List which can be reversed in <img class="formulaInl" alt="$\mathcal{O}(1)$" src="form_7.png">.
  36. <a href="#_details">More...</a>
  37. <p>
  38. <p>
  39. <a href="a00204.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0">
  40. <tr><td></td></tr>
  41. <tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr>
  42. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="678dc0ddb02994195a2359a361ee0ea6"></a><!-- doxytag: member="symlist::symlist" ref="678dc0ddb02994195a2359a361ee0ea6" args="()" -->
  43. &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#678dc0ddb02994195a2359a361ee0ea6">symlist</a> ()</td></tr>
  44. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Creates empty <a class="el" href="a00027.html" title="List which can be reversed in .">symlist</a>. <br></td></tr>
  45. <tr><td class="memItemLeft" nowrap align="right" valign="top">&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#5c17d54592dac03b2c4d940a10153797">symlist</a> (const <a class="el" href="a00027.html">symlist</a>&lt; T &gt; &amp;li)</td></tr>
  46. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Makes the created list a copy of <code>li</code>. <a href="#5c17d54592dac03b2c4d940a10153797"></a><br></td></tr>
  47. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="a00027.html">symlist</a>&lt; T &gt; &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#ab326eda0f6d3a78f193a249342670bc">operator=</a> (const <a class="el" href="a00027.html">symlist</a>&lt; T &gt; &amp;li)</td></tr>
  48. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Assignes <code>li</code> to this list. <a href="#ab326eda0f6d3a78f193a249342670bc"></a><br></td></tr>
  49. <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="45c3a0b7f0e996998037fb876effefd4"></a><!-- doxytag: member="symlist::~symlist" ref="45c3a0b7f0e996998037fb876effefd4" args="()" -->
  50. &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#45c3a0b7f0e996998037fb876effefd4">~symlist</a> ()</td></tr>
  51. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Destructor. <br></td></tr>
  52. <tr><td class="memItemLeft" nowrap align="right" valign="top">bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#a09d7b1edcb879524dd200cecf7f5f72">empty</a> () const </td></tr>
  53. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Checks whether list is empty. <a href="#a09d7b1edcb879524dd200cecf7f5f72"></a><br></td></tr>
  54. <tr><td class="memItemLeft" nowrap align="right" valign="top">T &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#fd4b55616fc20033d4a47684551866e8">front</a> ()</td></tr>
  55. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">First element in list. <a href="#fd4b55616fc20033d4a47684551866e8"></a><br></td></tr>
  56. <tr><td class="memItemLeft" nowrap align="right" valign="top">T &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#bc0570ff78ded9210ac26865519d36e3">back</a> ()</td></tr>
  57. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Last element in list. <a href="#bc0570ff78ded9210ac26865519d36e3"></a><br></td></tr>
  58. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#525b8d44af5d771fe15916372515cce0">begin</a> ()</td></tr>
  59. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Start iteration through elements of list. <a href="#525b8d44af5d771fe15916372515cce0"></a><br></td></tr>
  60. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#7283589fa01f79d722f8256d7a6a7883">end</a> ()</td></tr>
  61. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">End of iteration through elements of list. <a href="#7283589fa01f79d722f8256d7a6a7883"></a><br></td></tr>
  62. <tr><td class="memItemLeft" nowrap align="right" valign="top">const_iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#7c714327f88430cb7caeb1ecd67afd95">begin</a> () const </td></tr>
  63. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Start iteration through elements of list. <a href="#7c714327f88430cb7caeb1ecd67afd95"></a><br></td></tr>
  64. <tr><td class="memItemLeft" nowrap align="right" valign="top">const_iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#e7435efb58eeacee68c0268332ed1b0e">end</a> () const </td></tr>
  65. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">End of iteration through elements of list. <a href="#e7435efb58eeacee68c0268332ed1b0e"></a><br></td></tr>
  66. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#e5250e0c0c2bedee285f72584ddce29d">rbegin</a> ()</td></tr>
  67. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Start iteration through element of list in reverse order. <a href="#e5250e0c0c2bedee285f72584ddce29d"></a><br></td></tr>
  68. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#421fc482e62f257a9081e9e1c29d66a6">rend</a> ()</td></tr>
  69. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">End of iteration through elements of list in reverse order. <a href="#421fc482e62f257a9081e9e1c29d66a6"></a><br></td></tr>
  70. <tr><td class="memItemLeft" nowrap align="right" valign="top">const_iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#52e8efa766be554f4a5a788758c8b2e9">rbegin</a> () const </td></tr>
  71. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Start iteration through element of list in reverse order. <a href="#52e8efa766be554f4a5a788758c8b2e9"></a><br></td></tr>
  72. <tr><td class="memItemLeft" nowrap align="right" valign="top">const_iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#a33168957d1316726012faa6b01fb9d2">rend</a> () const </td></tr>
  73. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">End of iteration through elements of list in reverse order. <a href="#a33168957d1316726012faa6b01fb9d2"></a><br></td></tr>
  74. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#8a54cb9a00643d32c91a3b303140abb9">insert</a> (iterator pos, const T &amp;data)</td></tr>
  75. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Inserts <code>data</code> before <code>pos</code> in list. <a href="#8a54cb9a00643d32c91a3b303140abb9"></a><br></td></tr>
  76. <tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#c2bd4d9db62ea6a3282662c62a97c3b2">splice</a> (iterator pos, iterator it)</td></tr>
  77. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Inserts the element <code>it</code> points to before <code>pos</code> into this list. <a href="#c2bd4d9db62ea6a3282662c62a97c3b2"></a><br></td></tr>
  78. <tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#27889c85e97c1e8dec7a871987a12b29">splice</a> (iterator pos, iterator it, iterator end)</td></tr>
  79. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Inserts the elements <code>[it,end)</code> refers to before <code>pos</code> into this list. <a href="#27889c85e97c1e8dec7a871987a12b29"></a><br></td></tr>
  80. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#75fc1fc7db7b20cc430ddb8577608904">erase</a> (iterator pos)</td></tr>
  81. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Deletes element at position <code>pos</code> from list. <a href="#75fc1fc7db7b20cc430ddb8577608904"></a><br></td></tr>
  82. <tr><td class="memItemLeft" nowrap align="right" valign="top">iterator&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#53128defa9aedb016affcfa27bf201da">erase</a> (iterator it, iterator end)</td></tr>
  83. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Deletes the elements <code>[it, end)</code> from list. <a href="#53128defa9aedb016affcfa27bf201da"></a><br></td></tr>
  84. <tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00027.html#e22b65101604c694e96974cc9579ab78">reverse</a> ()</td></tr>
  85. <tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Change the direction of list. <a href="#e22b65101604c694e96974cc9579ab78"></a><br></td></tr>
  86. </table>
  87. <hr><a name="_details"></a><h2>Detailed Description</h2>
  88. <h3>template&lt;class T&gt;<br>
  89. class symlist&lt; T &gt;</h3>
  90. List which can be reversed in <img class="formulaInl" alt="$\mathcal{O}(1)$" src="form_7.png">.
  91. <p>
  92. The problem with the STL class list - as with most doubly linked lists -- is that isn't possible to turn it in constant time, because each entry in the list contains next and prev pointer and turning the list means to switch these two in <em>each</em> element in the list. Another point is the splice operation in STL lists, which is constant time, but for the same reason as mentioned above it is not possible to splice a list in reverse order into another in constant time. <p>
  93. The problems arise from the fact that each element "knows" what its next and previous elements are. An element in a <a class="el" href="a00027.html" title="List which can be reversed in .">symlist</a> only knows what its neighbors are, what is next and what previous depends on the direction of iteration. This of course imposes some overhead in iteration (one if-statement) but allows reversion and a splice in reversed order in constant time. <hr><h2>Constructor &amp; Destructor Documentation</h2>
  94. <a class="anchor" name="5c17d54592dac03b2c4d940a10153797"></a><!-- doxytag: member="symlist::symlist" ref="5c17d54592dac03b2c4d940a10153797" args="(const symlist&lt; T &gt; &amp;li)" -->
  95. <div class="memitem">
  96. <div class="memproto">
  97. <div class="memtemplate">
  98. template&lt;class T&gt; </div>
  99. <table class="memname">
  100. <tr>
  101. <td class="memname"><a class="el" href="a00027.html">symlist</a>&lt; T &gt;::<a class="el" href="a00027.html">symlist</a> </td>
  102. <td>(</td>
  103. <td class="paramtype">const <a class="el" href="a00027.html">symlist</a>&lt; T &gt; &amp;&nbsp;</td>
  104. <td class="paramname"> <em>li</em> </td>
  105. <td>&nbsp;)&nbsp;</td>
  106. <td width="100%"><code> [inline]</code></td>
  107. </tr>
  108. </table>
  109. </div>
  110. <div class="memdoc">
  111. <p>
  112. Makes the created list a copy of <code>li</code>.
  113. <p>
  114. <dl compact><dt><b>Parameters:</b></dt><dd>
  115. <table border="0" cellspacing="2" cellpadding="0">
  116. <tr><td valign="top"></td><td valign="top"><em>li</em>&nbsp;</td><td><a class="el" href="a00027.html" title="List which can be reversed in .">symlist</a>. </td></tr>
  117. </table>
  118. </dl>
  119. </div>
  120. </div><p>
  121. <hr><h2>Member Function Documentation</h2>
  122. <a class="anchor" name="ab326eda0f6d3a78f193a249342670bc"></a><!-- doxytag: member="symlist::operator=" ref="ab326eda0f6d3a78f193a249342670bc" args="(const symlist&lt; T &gt; &amp;li)" -->
  123. <div class="memitem">
  124. <div class="memproto">
  125. <div class="memtemplate">
  126. template&lt;class T&gt; </div>
  127. <table class="memname">
  128. <tr>
  129. <td class="memname"><a class="el" href="a00027.html">symlist</a>&lt; T &gt; &amp; <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::operator= </td>
  130. <td>(</td>
  131. <td class="paramtype">const <a class="el" href="a00027.html">symlist</a>&lt; T &gt; &amp;&nbsp;</td>
  132. <td class="paramname"> <em>li</em> </td>
  133. <td>&nbsp;)&nbsp;</td>
  134. <td width="100%"><code> [inline]</code></td>
  135. </tr>
  136. </table>
  137. </div>
  138. <div class="memdoc">
  139. <p>
  140. Assignes <code>li</code> to this list.
  141. <p>
  142. <dl class="note" compact><dt><b>Note:</b></dt><dd>All elements in this list will be deleted.</dd></dl>
  143. <dl compact><dt><b>Parameters:</b></dt><dd>
  144. <table border="0" cellspacing="2" cellpadding="0">
  145. <tr><td valign="top"></td><td valign="top"><em>li</em>&nbsp;</td><td></td></tr>
  146. </table>
  147. </dl>
  148. <dl class="return" compact><dt><b>Returns:</b></dt><dd>this list </dd></dl>
  149. </div>
  150. </div><p>
  151. <a class="anchor" name="a09d7b1edcb879524dd200cecf7f5f72"></a><!-- doxytag: member="symlist::empty" ref="a09d7b1edcb879524dd200cecf7f5f72" args="() const " -->
  152. <div class="memitem">
  153. <div class="memproto">
  154. <div class="memtemplate">
  155. template&lt;class T&gt; </div>
  156. <table class="memname">
  157. <tr>
  158. <td class="memname">bool <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::empty </td>
  159. <td>(</td>
  160. <td class="paramname"> </td>
  161. <td>&nbsp;)&nbsp;</td>
  162. <td width="100%"> const<code> [inline]</code></td>
  163. </tr>
  164. </table>
  165. </div>
  166. <div class="memdoc">
  167. <p>
  168. Checks whether list is empty.
  169. <p>
  170. Takes constant time.<p>
  171. <dl compact><dt><b>Return values:</b></dt><dd>
  172. <table border="0" cellspacing="2" cellpadding="0">
  173. <tr><td valign="top"></td><td valign="top"><em>true</em>&nbsp;</td><td>iff list is empty </td></tr>
  174. </table>
  175. </dl>
  176. </div>
  177. </div><p>
  178. <a class="anchor" name="fd4b55616fc20033d4a47684551866e8"></a><!-- doxytag: member="symlist::front" ref="fd4b55616fc20033d4a47684551866e8" args="()" -->
  179. <div class="memitem">
  180. <div class="memproto">
  181. <div class="memtemplate">
  182. template&lt;class T&gt; </div>
  183. <table class="memname">
  184. <tr>
  185. <td class="memname">T&amp; <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::front </td>
  186. <td>(</td>
  187. <td class="paramname"> </td>
  188. <td>&nbsp;)&nbsp;</td>
  189. <td width="100%"><code> [inline]</code></td>
  190. </tr>
  191. </table>
  192. </div>
  193. <div class="memdoc">
  194. <p>
  195. First element in list.
  196. <p>
  197. Assumes that list ins't empty.<p>
  198. <dl class="return" compact><dt><b>Returns:</b></dt><dd>first element </dd></dl>
  199. </div>
  200. </div><p>
  201. <a class="anchor" name="bc0570ff78ded9210ac26865519d36e3"></a><!-- doxytag: member="symlist::back" ref="bc0570ff78ded9210ac26865519d36e3" args="()" -->
  202. <div class="memitem">
  203. <div class="memproto">
  204. <div class="memtemplate">
  205. template&lt;class T&gt; </div>
  206. <table class="memname">
  207. <tr>
  208. <td class="memname">T&amp; <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::back </td>
  209. <td>(</td>
  210. <td class="paramname"> </td>
  211. <td>&nbsp;)&nbsp;</td>
  212. <td width="100%"><code> [inline]</code></td>
  213. </tr>
  214. </table>
  215. </div>
  216. <div class="memdoc">
  217. <p>
  218. Last element in list.
  219. <p>
  220. Assumes that list ins't empty.<p>
  221. <dl class="return" compact><dt><b>Returns:</b></dt><dd>last element </dd></dl>
  222. </div>
  223. </div><p>
  224. <a class="anchor" name="525b8d44af5d771fe15916372515cce0"></a><!-- doxytag: member="symlist::begin" ref="525b8d44af5d771fe15916372515cce0" args="()" -->
  225. <div class="memitem">
  226. <div class="memproto">
  227. <div class="memtemplate">
  228. template&lt;class T&gt; </div>
  229. <table class="memname">
  230. <tr>
  231. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::begin </td>
  232. <td>(</td>
  233. <td class="paramname"> </td>
  234. <td>&nbsp;)&nbsp;</td>
  235. <td width="100%"><code> [inline]</code></td>
  236. </tr>
  237. </table>
  238. </div>
  239. <div class="memdoc">
  240. <p>
  241. Start iteration through elements of list.
  242. <p>
  243. <dl class="return" compact><dt><b>Returns:</b></dt><dd>start iterator </dd></dl>
  244. </div>
  245. </div><p>
  246. <a class="anchor" name="7283589fa01f79d722f8256d7a6a7883"></a><!-- doxytag: member="symlist::end" ref="7283589fa01f79d722f8256d7a6a7883" args="()" -->
  247. <div class="memitem">
  248. <div class="memproto">
  249. <div class="memtemplate">
  250. template&lt;class T&gt; </div>
  251. <table class="memname">
  252. <tr>
  253. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::end </td>
  254. <td>(</td>
  255. <td class="paramname"> </td>
  256. <td>&nbsp;)&nbsp;</td>
  257. <td width="100%"><code> [inline]</code></td>
  258. </tr>
  259. </table>
  260. </div>
  261. <div class="memdoc">
  262. <p>
  263. End of iteration through elements of list.
  264. <p>
  265. <dl class="return" compact><dt><b>Returns:</b></dt><dd>end iterator </dd></dl>
  266. </div>
  267. </div><p>
  268. <a class="anchor" name="7c714327f88430cb7caeb1ecd67afd95"></a><!-- doxytag: member="symlist::begin" ref="7c714327f88430cb7caeb1ecd67afd95" args="() const " -->
  269. <div class="memitem">
  270. <div class="memproto">
  271. <div class="memtemplate">
  272. template&lt;class T&gt; </div>
  273. <table class="memname">
  274. <tr>
  275. <td class="memname">const_iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::begin </td>
  276. <td>(</td>
  277. <td class="paramname"> </td>
  278. <td>&nbsp;)&nbsp;</td>
  279. <td width="100%"> const<code> [inline]</code></td>
  280. </tr>
  281. </table>
  282. </div>
  283. <div class="memdoc">
  284. <p>
  285. Start iteration through elements of list.
  286. <p>
  287. <dl class="return" compact><dt><b>Returns:</b></dt><dd>start iterator </dd></dl>
  288. </div>
  289. </div><p>
  290. <a class="anchor" name="e7435efb58eeacee68c0268332ed1b0e"></a><!-- doxytag: member="symlist::end" ref="e7435efb58eeacee68c0268332ed1b0e" args="() const " -->
  291. <div class="memitem">
  292. <div class="memproto">
  293. <div class="memtemplate">
  294. template&lt;class T&gt; </div>
  295. <table class="memname">
  296. <tr>
  297. <td class="memname">const_iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::end </td>
  298. <td>(</td>
  299. <td class="paramname"> </td>
  300. <td>&nbsp;)&nbsp;</td>
  301. <td width="100%"> const<code> [inline]</code></td>
  302. </tr>
  303. </table>
  304. </div>
  305. <div class="memdoc">
  306. <p>
  307. End of iteration through elements of list.
  308. <p>
  309. <dl class="return" compact><dt><b>Returns:</b></dt><dd>end iterator </dd></dl>
  310. </div>
  311. </div><p>
  312. <a class="anchor" name="e5250e0c0c2bedee285f72584ddce29d"></a><!-- doxytag: member="symlist::rbegin" ref="e5250e0c0c2bedee285f72584ddce29d" args="()" -->
  313. <div class="memitem">
  314. <div class="memproto">
  315. <div class="memtemplate">
  316. template&lt;class T&gt; </div>
  317. <table class="memname">
  318. <tr>
  319. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::rbegin </td>
  320. <td>(</td>
  321. <td class="paramname"> </td>
  322. <td>&nbsp;)&nbsp;</td>
  323. <td width="100%"><code> [inline]</code></td>
  324. </tr>
  325. </table>
  326. </div>
  327. <div class="memdoc">
  328. <p>
  329. Start iteration through element of list in reverse order.
  330. <p>
  331. <dl class="return" compact><dt><b>Returns:</b></dt><dd>start iterator </dd></dl>
  332. </div>
  333. </div><p>
  334. <a class="anchor" name="421fc482e62f257a9081e9e1c29d66a6"></a><!-- doxytag: member="symlist::rend" ref="421fc482e62f257a9081e9e1c29d66a6" args="()" -->
  335. <div class="memitem">
  336. <div class="memproto">
  337. <div class="memtemplate">
  338. template&lt;class T&gt; </div>
  339. <table class="memname">
  340. <tr>
  341. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::rend </td>
  342. <td>(</td>
  343. <td class="paramname"> </td>
  344. <td>&nbsp;)&nbsp;</td>
  345. <td width="100%"><code> [inline]</code></td>
  346. </tr>
  347. </table>
  348. </div>
  349. <div class="memdoc">
  350. <p>
  351. End of iteration through elements of list in reverse order.
  352. <p>
  353. <dl class="return" compact><dt><b>Returns:</b></dt><dd>end iterator </dd></dl>
  354. </div>
  355. </div><p>
  356. <a class="anchor" name="52e8efa766be554f4a5a788758c8b2e9"></a><!-- doxytag: member="symlist::rbegin" ref="52e8efa766be554f4a5a788758c8b2e9" args="() const " -->
  357. <div class="memitem">
  358. <div class="memproto">
  359. <div class="memtemplate">
  360. template&lt;class T&gt; </div>
  361. <table class="memname">
  362. <tr>
  363. <td class="memname">const_iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::rbegin </td>
  364. <td>(</td>
  365. <td class="paramname"> </td>
  366. <td>&nbsp;)&nbsp;</td>
  367. <td width="100%"> const<code> [inline]</code></td>
  368. </tr>
  369. </table>
  370. </div>
  371. <div class="memdoc">
  372. <p>
  373. Start iteration through element of list in reverse order.
  374. <p>
  375. <dl class="return" compact><dt><b>Returns:</b></dt><dd>start iterator </dd></dl>
  376. </div>
  377. </div><p>
  378. <a class="anchor" name="a33168957d1316726012faa6b01fb9d2"></a><!-- doxytag: member="symlist::rend" ref="a33168957d1316726012faa6b01fb9d2" args="() const " -->
  379. <div class="memitem">
  380. <div class="memproto">
  381. <div class="memtemplate">
  382. template&lt;class T&gt; </div>
  383. <table class="memname">
  384. <tr>
  385. <td class="memname">const_iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::rend </td>
  386. <td>(</td>
  387. <td class="paramname"> </td>
  388. <td>&nbsp;)&nbsp;</td>
  389. <td width="100%"> const<code> [inline]</code></td>
  390. </tr>
  391. </table>
  392. </div>
  393. <div class="memdoc">
  394. <p>
  395. End of iteration through elements of list in reverse order.
  396. <p>
  397. <dl class="return" compact><dt><b>Returns:</b></dt><dd>end iterator </dd></dl>
  398. </div>
  399. </div><p>
  400. <a class="anchor" name="8a54cb9a00643d32c91a3b303140abb9"></a><!-- doxytag: member="symlist::insert" ref="8a54cb9a00643d32c91a3b303140abb9" args="(iterator pos, const T &amp;data)" -->
  401. <div class="memitem">
  402. <div class="memproto">
  403. <div class="memtemplate">
  404. template&lt;class T&gt; </div>
  405. <table class="memname">
  406. <tr>
  407. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::insert </td>
  408. <td>(</td>
  409. <td class="paramtype">iterator&nbsp;</td>
  410. <td class="paramname"> <em>pos</em>, </td>
  411. </tr>
  412. <tr>
  413. <td class="paramkey"></td>
  414. <td></td>
  415. <td class="paramtype">const T &amp;&nbsp;</td>
  416. <td class="paramname"> <em>data</em></td><td>&nbsp;</td>
  417. </tr>
  418. <tr>
  419. <td></td>
  420. <td>)</td>
  421. <td></td><td></td><td width="100%"></td>
  422. </tr>
  423. </table>
  424. </div>
  425. <div class="memdoc">
  426. <p>
  427. Inserts <code>data</code> before <code>pos</code> in list.
  428. <p>
  429. <dl compact><dt><b>Parameters:</b></dt><dd>
  430. <table border="0" cellspacing="2" cellpadding="0">
  431. <tr><td valign="top"></td><td valign="top"><em>pos</em>&nbsp;</td><td>position </td></tr>
  432. <tr><td valign="top"></td><td valign="top"><em>data</em>&nbsp;</td><td>element to be inserted</td></tr>
  433. </table>
  434. </dl>
  435. <dl class="return" compact><dt><b>Returns:</b></dt><dd>position of insertion </dd></dl>
  436. </div>
  437. </div><p>
  438. <a class="anchor" name="c2bd4d9db62ea6a3282662c62a97c3b2"></a><!-- doxytag: member="symlist::splice" ref="c2bd4d9db62ea6a3282662c62a97c3b2" args="(iterator pos, iterator it)" -->
  439. <div class="memitem">
  440. <div class="memproto">
  441. <div class="memtemplate">
  442. template&lt;class T&gt; </div>
  443. <table class="memname">
  444. <tr>
  445. <td class="memname">void <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::splice </td>
  446. <td>(</td>
  447. <td class="paramtype">iterator&nbsp;</td>
  448. <td class="paramname"> <em>pos</em>, </td>
  449. </tr>
  450. <tr>
  451. <td class="paramkey"></td>
  452. <td></td>
  453. <td class="paramtype">iterator&nbsp;</td>
  454. <td class="paramname"> <em>it</em></td><td>&nbsp;</td>
  455. </tr>
  456. <tr>
  457. <td></td>
  458. <td>)</td>
  459. <td></td><td></td><td width="100%"></td>
  460. </tr>
  461. </table>
  462. </div>
  463. <div class="memdoc">
  464. <p>
  465. Inserts the element <code>it</code> points to before <code>pos</code> into this list.
  466. <p>
  467. It is assumed that the element <code>it</code> refers lies in a different list. All iterators to elements in either of the two lists stay valid. Takes constant time.<p>
  468. <dl compact><dt><b>Parameters:</b></dt><dd>
  469. <table border="0" cellspacing="2" cellpadding="0">
  470. <tr><td valign="top"></td><td valign="top"><em>pos</em>&nbsp;</td><td>position </td></tr>
  471. <tr><td valign="top"></td><td valign="top"><em>it</em>&nbsp;</td><td>position of element to be inserted </td></tr>
  472. </table>
  473. </dl>
  474. </div>
  475. </div><p>
  476. <a class="anchor" name="27889c85e97c1e8dec7a871987a12b29"></a><!-- doxytag: member="symlist::splice" ref="27889c85e97c1e8dec7a871987a12b29" args="(iterator pos, iterator it, iterator end)" -->
  477. <div class="memitem">
  478. <div class="memproto">
  479. <div class="memtemplate">
  480. template&lt;class T&gt; </div>
  481. <table class="memname">
  482. <tr>
  483. <td class="memname">void <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::splice </td>
  484. <td>(</td>
  485. <td class="paramtype">iterator&nbsp;</td>
  486. <td class="paramname"> <em>pos</em>, </td>
  487. </tr>
  488. <tr>
  489. <td class="paramkey"></td>
  490. <td></td>
  491. <td class="paramtype">iterator&nbsp;</td>
  492. <td class="paramname"> <em>it</em>, </td>
  493. </tr>
  494. <tr>
  495. <td class="paramkey"></td>
  496. <td></td>
  497. <td class="paramtype">iterator&nbsp;</td>
  498. <td class="paramname"> <em>end</em></td><td>&nbsp;</td>
  499. </tr>
  500. <tr>
  501. <td></td>
  502. <td>)</td>
  503. <td></td><td></td><td width="100%"></td>
  504. </tr>
  505. </table>
  506. </div>
  507. <div class="memdoc">
  508. <p>
  509. Inserts the elements <code>[it,end)</code> refers to before <code>pos</code> into this list.
  510. <p>
  511. It is assumed that <code>[it,end)</code> lies in a different list. All iterators to elements in either of the two lists stay valid. Takes constant time.<p>
  512. <dl compact><dt><b>Parameters:</b></dt><dd>
  513. <table border="0" cellspacing="2" cellpadding="0">
  514. <tr><td valign="top"></td><td valign="top"><em>pos</em>&nbsp;</td><td>position </td></tr>
  515. <tr><td valign="top"></td><td valign="top"><em>it</em>&nbsp;</td><td>position of first element to be inserted </td></tr>
  516. <tr><td valign="top"></td><td valign="top"><em>end</em>&nbsp;</td><td>position of one-past the last element to be inserted </td></tr>
  517. </table>
  518. </dl>
  519. </div>
  520. </div><p>
  521. <a class="anchor" name="75fc1fc7db7b20cc430ddb8577608904"></a><!-- doxytag: member="symlist::erase" ref="75fc1fc7db7b20cc430ddb8577608904" args="(iterator pos)" -->
  522. <div class="memitem">
  523. <div class="memproto">
  524. <div class="memtemplate">
  525. template&lt;class T&gt; </div>
  526. <table class="memname">
  527. <tr>
  528. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::erase </td>
  529. <td>(</td>
  530. <td class="paramtype">iterator&nbsp;</td>
  531. <td class="paramname"> <em>pos</em> </td>
  532. <td>&nbsp;)&nbsp;</td>
  533. <td width="100%"></td>
  534. </tr>
  535. </table>
  536. </div>
  537. <div class="memdoc">
  538. <p>
  539. Deletes element at position <code>pos</code> from list.
  540. <p>
  541. <dl compact><dt><b>Parameters:</b></dt><dd>
  542. <table border="0" cellspacing="2" cellpadding="0">
  543. <tr><td valign="top"></td><td valign="top"><em>pos</em>&nbsp;</td><td>position to be deleted</td></tr>
  544. </table>
  545. </dl>
  546. <dl class="return" compact><dt><b>Returns:</b></dt><dd>position of next element </dd></dl>
  547. </div>
  548. </div><p>
  549. <a class="anchor" name="53128defa9aedb016affcfa27bf201da"></a><!-- doxytag: member="symlist::erase" ref="53128defa9aedb016affcfa27bf201da" args="(iterator it, iterator end)" -->
  550. <div class="memitem">
  551. <div class="memproto">
  552. <div class="memtemplate">
  553. template&lt;class T&gt; </div>
  554. <table class="memname">
  555. <tr>
  556. <td class="memname">iterator <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::erase </td>
  557. <td>(</td>
  558. <td class="paramtype">iterator&nbsp;</td>
  559. <td class="paramname"> <em>it</em>, </td>
  560. </tr>
  561. <tr>
  562. <td class="paramkey"></td>
  563. <td></td>
  564. <td class="paramtype">iterator&nbsp;</td>
  565. <td class="paramname"> <em>end</em></td><td>&nbsp;</td>
  566. </tr>
  567. <tr>
  568. <td></td>
  569. <td>)</td>
  570. <td></td><td></td><td width="100%"></td>
  571. </tr>
  572. </table>
  573. </div>
  574. <div class="memdoc">
  575. <p>
  576. Deletes the elements <code>[it, end)</code> from list.
  577. <p>
  578. <dl compact><dt><b>Parameters:</b></dt><dd>
  579. <table border="0" cellspacing="2" cellpadding="0">
  580. <tr><td valign="top"></td><td valign="top"><em>it</em>&nbsp;</td><td>first position to be deleted </td></tr>
  581. <tr><td valign="top"></td><td valign="top"><em>end</em>&nbsp;</td><td>one-past the last position to be deleted</td></tr>
  582. </table>
  583. </dl>
  584. <dl class="return" compact><dt><b>Returns:</b></dt><dd>position of next element. </dd></dl>
  585. </div>
  586. </div><p>
  587. <a class="anchor" name="e22b65101604c694e96974cc9579ab78"></a><!-- doxytag: member="symlist::reverse" ref="e22b65101604c694e96974cc9579ab78" args="()" -->
  588. <div class="memitem">
  589. <div class="memproto">
  590. <div class="memtemplate">
  591. template&lt;class T&gt; </div>
  592. <table class="memname">
  593. <tr>
  594. <td class="memname">void <a class="el" href="a00027.html">symlist</a>&lt; T &gt;::reverse </td>
  595. <td>(</td>
  596. <td class="paramname"> </td>
  597. <td>&nbsp;)&nbsp;</td>
  598. <td width="100%"><code> [inline]</code></td>
  599. </tr>
  600. </table>
  601. </div>
  602. <div class="memdoc">
  603. <p>
  604. Change the direction of list.
  605. <p>
  606. Takes constant time.
  607. </div>
  608. </div><p>
  609. <p class="links">
  610. <a href="http://www.uni-passau.de/">University of Passau</a>
  611. &nbsp;-&nbsp;
  612. <a href="http://www.fmi.uni-passau.de/">FMI</a>
  613. &nbsp;-&nbsp;
  614. <a href="http://www.fmi.uni-passau.de/fmi/lehrstuehle/brandenburg/">Theoretical
  615. Computer Science</a>
  616. </p>
  617. <div class="copyright">
  618. Design &copy; 2002, 2003 <a href="mailto:raitner@fmi.uni-passau.de">Marcus Raitner</a>, University of Passau
  619. </div>
  620. </body>
  621. </html>