A<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B_Tutorial%2Fdeque%2Fdeque_iterator</id>
		<title>C++ Tutorial/deque/deque iterator - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B_Tutorial%2Fdeque%2Fdeque_iterator"/>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/deque/deque_iterator&amp;action=history"/>
		<updated>2026-04-17T17:51:25Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/deque/deque_iterator&amp;diff=2511&amp;oldid=prev</id>
		<title> в 14:21, 25 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/deque/deque_iterator&amp;diff=2511&amp;oldid=prev"/>
				<updated>2010-05-25T14:21:17Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 14:21, 25 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/deque/deque_iterator&amp;diff=2512&amp;oldid=prev</id>
		<title>Admin: 1 версия:&amp;#32;Импорт контента...</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B_Tutorial/deque/deque_iterator&amp;diff=2512&amp;oldid=prev"/>
				<updated>2010-05-25T10:29:53Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия: Импорт контента...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Create an empty deque and then assign it a sequence that is the reverse of deque==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
void show(const char *msg, deque&amp;lt;int&amp;gt; q);&lt;br /&gt;
int main() {&lt;br /&gt;
  deque&amp;lt;int&amp;gt; dq(10);&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; dq.size(); ++i) dq[i] = i*i;&lt;br /&gt;
  show(&amp;quot;Contents of dq: &amp;quot;, dq);&lt;br /&gt;
  // Create an empty deque and then assign it a sequence that is the reverse of dq.&lt;br /&gt;
  deque&amp;lt;int&amp;gt; dq3;&lt;br /&gt;
  dq3.assign(dq.rbegin(), dq.rend());&lt;br /&gt;
  show(&amp;quot;dq3 contains the reverse of dq: &amp;quot;, dq3);&lt;br /&gt;
  cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
// Display the contents of a deque&amp;lt;int&amp;gt;.&lt;br /&gt;
void show(const char *msg, deque&amp;lt;int&amp;gt; q) {&lt;br /&gt;
  cout &amp;lt;&amp;lt; msg;&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; q.size(); ++i)&lt;br /&gt;
    cout &amp;lt;&amp;lt; q[i] &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;\n&amp;quot;;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Define iterator for deque==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;// Demonstrating the generic find algorithm with a deque&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;cassert&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;  // For find&lt;br /&gt;
using namespace std;&lt;br /&gt;
&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  int x[5] = {1, 2, 3, 4, 5};&lt;br /&gt;
  deque&amp;lt;int&amp;gt; deque1(&amp;amp;x[0], &amp;amp;x[5]);&lt;br /&gt;
  // Search for the first occurrence of the letter e:&lt;br /&gt;
  deque&amp;lt;int&amp;gt;::iterator i;&lt;br /&gt;
  cout.precision(10);&lt;br /&gt;
  for (i = deque1.begin(); i != deque1.end(); ++i)&lt;br /&gt;
    cout &amp;lt;&amp;lt; *i &amp;lt;&amp;lt; endl;&lt;br /&gt;
  return 0;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;1&lt;br /&gt;
2&lt;br /&gt;
3&lt;br /&gt;
4&lt;br /&gt;
5&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==deque&amp;lt;int&amp;gt;::iterator and deque&amp;lt;int&amp;gt;::reverse_iterator==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
void show(const char *msg, deque&amp;lt;int&amp;gt; q);&lt;br /&gt;
int main() {&lt;br /&gt;
  deque&amp;lt;int&amp;gt; dq(10);&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; dq.size(); ++i) dq[i] = i*i;&lt;br /&gt;
  show(&amp;quot;Contents of dq: &amp;quot;, dq);&lt;br /&gt;
  deque&amp;lt;int&amp;gt;::iterator itr;&lt;br /&gt;
  deque&amp;lt;int&amp;gt;::reverse_iterator ritr;&lt;br /&gt;
  for(itr = dq.begin(); itr != dq.end(); ++itr)&lt;br /&gt;
    cout &amp;lt;&amp;lt; *itr &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
 &lt;br /&gt;
  for(ritr = dq.rbegin(); ritr != dq.rend(); ++ritr)&lt;br /&gt;
    cout &amp;lt;&amp;lt; *ritr &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
 &lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
// Display the contents of a deque&amp;lt;int&amp;gt;.&lt;br /&gt;
void show(const char *msg, deque&amp;lt;int&amp;gt; q) {&lt;br /&gt;
  cout &amp;lt;&amp;lt; msg;&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; q.size(); ++i)&lt;br /&gt;
    cout &amp;lt;&amp;lt; q[i] &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;\n&amp;quot;;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Print the contents in reverse order using reverse_iterator and functions rbegin() and rend()==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
typedef deque&amp;lt;int&amp;gt; INTDEQUE;&lt;br /&gt;
int main(void)&lt;br /&gt;
{&lt;br /&gt;
   INTDEQUE A;&lt;br /&gt;
   A.push_back(1);&lt;br /&gt;
   A.push_back(2);&lt;br /&gt;
   A.push_back(3);&lt;br /&gt;
   A.push_back(4);&lt;br /&gt;
   A.push_back(5);&lt;br /&gt;
   INTDEQUE::reverse_iterator rpi;&lt;br /&gt;
   for(rpi = A.rbegin(); rpi != A.rend(); rpi++)&lt;br /&gt;
      cout &amp;lt;&amp;lt; *rpi &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
   cout&amp;lt;&amp;lt; endl;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Use insert iterator adaptors to insert one deque into another by way of the copy() algorithm.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
void show(const char *msg, deque&amp;lt;string&amp;gt; dq);&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  deque&amp;lt;string&amp;gt; dq, dq2, dq3, dq4;&lt;br /&gt;
  dq.push_back(&amp;quot;A&amp;quot;);&lt;br /&gt;
  dq.push_back(&amp;quot;B&amp;quot;);&lt;br /&gt;
  dq.push_back(&amp;quot;C&amp;quot;);&lt;br /&gt;
  dq.push_back(&amp;quot;D&amp;quot;);&lt;br /&gt;
  dq.push_back(&amp;quot;E&amp;quot;);&lt;br /&gt;
  dq.push_back(&amp;quot;F.&amp;quot;);&lt;br /&gt;
  dq2.push_back(&amp;quot;G&amp;quot;);&lt;br /&gt;
  dq2.push_back(&amp;quot;H&amp;quot;);&lt;br /&gt;
  dq2.push_back(&amp;quot;I&amp;quot;);&lt;br /&gt;
  dq3.push_back(&amp;quot;J&amp;quot;);&lt;br /&gt;
  dq3.push_back(&amp;quot;K&amp;quot;);&lt;br /&gt;
  dq3.push_back(&amp;quot;L&amp;quot;);&lt;br /&gt;
  dq4.push_back(&amp;quot;M&amp;quot;);&lt;br /&gt;
  dq4.push_back(&amp;quot;N&amp;quot;);&lt;br /&gt;
  dq4.push_back(&amp;quot;O&amp;quot;);&lt;br /&gt;
  cout &amp;lt;&amp;lt; dq.size() &amp;lt;&amp;lt; endl;&lt;br /&gt;
  show(&amp;quot;Original contents of dq:&amp;quot;, dq);&lt;br /&gt;
  // Use an insert_iterator to insert dq2 into dq.&lt;br /&gt;
  copy(dq2.begin(), dq2.end(), inserter(dq, dq.begin()+3));&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Size of dq after inserting dq2: &amp;quot; &amp;lt;&amp;lt; dq.size() &amp;lt;&amp;lt; endl;&lt;br /&gt;
  show(&amp;quot;dq2:&amp;quot;, dq);&lt;br /&gt;
  // Use a back_insert_iterator to insert dq3 into dq.&lt;br /&gt;
  copy(dq3.begin(), dq3.end(), back_inserter(dq));&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Size of dq after inserting dq3: &amp;quot;;&lt;br /&gt;
  cout &amp;lt;&amp;lt; dq.size() &amp;lt;&amp;lt; endl;&lt;br /&gt;
  show(&amp;quot;dq3:&amp;quot;, dq);&lt;br /&gt;
  // Use a front_insert_iterator to insert dq4 into dq.&lt;br /&gt;
  copy(dq4.begin(), dq4.end(), front_inserter(dq));&lt;br /&gt;
  cout &amp;lt;&amp;lt; &amp;quot;Size of dq after inserting dq4: &amp;quot; &amp;lt;&amp;lt; dq.size() &amp;lt;&amp;lt; endl;&lt;br /&gt;
  show(&amp;quot;dq4:&amp;quot;, dq);&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
void show(const char *msg, deque&amp;lt;string&amp;gt; dq) {&lt;br /&gt;
  cout &amp;lt;&amp;lt; msg &amp;lt;&amp;lt; endl;&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; dq.size(); ++i)&lt;br /&gt;
    cout &amp;lt;&amp;lt; dq[i] &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Use iterator and reverse_iterator with deque==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
void print (int elem)&lt;br /&gt;
{&lt;br /&gt;
    cout &amp;lt;&amp;lt; elem &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    deque&amp;lt;int&amp;gt; coll;&lt;br /&gt;
    // insert elements from 1 to 9&lt;br /&gt;
    for (int i=1; i&amp;lt;=9; ++i) {&lt;br /&gt;
        coll.push_back(i);&lt;br /&gt;
    }&lt;br /&gt;
    // find position of element with value 2&lt;br /&gt;
    deque&amp;lt;int&amp;gt;::iterator pos1;&lt;br /&gt;
    pos1 = find (coll.begin(), coll.end(),    // range&lt;br /&gt;
                 2);                          // value&lt;br /&gt;
    // find position of element with value 7&lt;br /&gt;
    deque&amp;lt;int&amp;gt;::iterator pos2;&lt;br /&gt;
    pos2 = find (coll.begin(), coll.end(),    // range&lt;br /&gt;
                 7);                          // value&lt;br /&gt;
    // print all elements in range [pos1,pos2)&lt;br /&gt;
    for_each (pos1, pos2,     // range&lt;br /&gt;
              print);         // operation&lt;br /&gt;
    cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
    // convert iterators to reverse iterators&lt;br /&gt;
    deque&amp;lt;int&amp;gt;::reverse_iterator rpos1(pos1);&lt;br /&gt;
    deque&amp;lt;int&amp;gt;::reverse_iterator rpos2(pos2);&lt;br /&gt;
    // print all elements in range [pos1,pos2) in reverse order&lt;br /&gt;
    for_each (rpos2, rpos1,   // range&lt;br /&gt;
              print);         // operation&lt;br /&gt;
    cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;2 3 4 5 6&lt;br /&gt;
6 5 4 3 2&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Using the Front of a Deque==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
void print(T&amp;amp; c){&lt;br /&gt;
   for( typename T::iterator i = c.begin(); i != c.end(); i++ ){&lt;br /&gt;
      std::cout &amp;lt;&amp;lt; *i &amp;lt;&amp;lt; endl;&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
class Auction_item&lt;br /&gt;
{&lt;br /&gt;
   public:&lt;br /&gt;
   Auction_item( const string&amp;amp; name = &amp;quot;nothing&amp;quot;,&lt;br /&gt;
      int minimum_bid = 0 );&lt;br /&gt;
   int minimum_bid() const;&lt;br /&gt;
   string name() const;&lt;br /&gt;
   private:&lt;br /&gt;
   int minimum_bid_;&lt;br /&gt;
   string name_;&lt;br /&gt;
};&lt;br /&gt;
inline&lt;br /&gt;
Auction_item::Auction_item( const string&amp;amp; name, int minimum_bid )&lt;br /&gt;
   : name_( name ), minimum_bid_( minimum_bid )&lt;br /&gt;
{}&lt;br /&gt;
inline&lt;br /&gt;
int Auction_item::minimum_bid() const{  return minimum_bid_; }&lt;br /&gt;
inline&lt;br /&gt;
string Auction_item::name() const{  return name_; }&lt;br /&gt;
int main( )&lt;br /&gt;
{&lt;br /&gt;
   vector&amp;lt;Auction_item&amp;gt; v( 5 );&lt;br /&gt;
   v[0] = Auction_item( &amp;quot;A&amp;quot;, 150 );&lt;br /&gt;
   v[1] = Auction_item( &amp;quot;B&amp;quot;, 10 );&lt;br /&gt;
   v[2] = Auction_item( &amp;quot;C&amp;quot;, 75 );&lt;br /&gt;
   v[3] = Auction_item( &amp;quot;D&amp;quot;, 20 );&lt;br /&gt;
   v[4] = Auction_item( &amp;quot;E&amp;quot;, 100 );&lt;br /&gt;
   deque&amp;lt;Auction_item&amp;gt; items;&lt;br /&gt;
   // load auction items with cheap ones in front, expensive at back&lt;br /&gt;
   const int min_expensive_item = 50;&lt;br /&gt;
   for( vector&amp;lt;Auction_item&amp;gt;::iterator i = v.begin();&lt;br /&gt;
      i != v.end(); ++i )&lt;br /&gt;
      if( i-&amp;gt;minimum_bid() &amp;gt;= min_expensive_item )&lt;br /&gt;
         items.push_back( *i );&lt;br /&gt;
      else&lt;br /&gt;
         items.push_front( *i );&lt;br /&gt;
   // sell the items&lt;br /&gt;
   bool sell_cheap = true;&lt;br /&gt;
   while( !items.empty() )&lt;br /&gt;
   {&lt;br /&gt;
      if( sell_cheap )&lt;br /&gt;
      {&lt;br /&gt;
         cout &amp;lt;&amp;lt; items.front().name()&lt;br /&gt;
            &amp;lt;&amp;lt; &amp;quot; for a minimum bid of &amp;quot;&lt;br /&gt;
            &amp;lt;&amp;lt; items.front().minimum_bid() &amp;lt;&amp;lt; endl;&lt;br /&gt;
         items.pop_front();&lt;br /&gt;
      }&lt;br /&gt;
      else&lt;br /&gt;
      {&lt;br /&gt;
         cout &amp;lt;&amp;lt; &amp;quot;Now selling: a &amp;quot; &amp;lt;&amp;lt; items.back().name()&lt;br /&gt;
            &amp;lt;&amp;lt; &amp;quot; for a minimum bid of &amp;quot;&lt;br /&gt;
            &amp;lt;&amp;lt; items.back().minimum_bid() &amp;lt;&amp;lt; endl;&lt;br /&gt;
         items.pop_back();&lt;br /&gt;
      }&lt;br /&gt;
      // Alternate selling cheap and expensive&lt;br /&gt;
      sell_cheap = !sell_cheap;&lt;br /&gt;
   }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>