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%2FData_Structure_Algorithm%2FQueue</id>
		<title>C/Data Structure Algorithm/Queue - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2FData_Structure_Algorithm%2FQueue"/>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Queue&amp;action=history"/>
		<updated>2026-04-17T21:27:18Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Queue&amp;diff=244&amp;oldid=prev</id>
		<title> в 14:20, 25 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Queue&amp;diff=244&amp;oldid=prev"/>
				<updated>2010-05-25T14:20:56Z</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:20, 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/Data_Structure_Algorithm/Queue&amp;diff=245&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/Data_Structure_Algorithm/Queue&amp;diff=245&amp;oldid=prev"/>
				<updated>2010-05-25T10:22:30Z</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;==A circular queue example using a keyboard buffer==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
C: The Complete Reference, 4th Ed. (Paperback)&lt;br /&gt;
by Herbert Schildt&lt;br /&gt;
ISBN: 0072121246&lt;br /&gt;
Publisher: McGraw-Hill Osborne Media; 4 edition (April 26, 2000)&lt;br /&gt;
*/&lt;br /&gt;
/* A circular queue example using a keyboard buffer. */&lt;br /&gt;
#include &amp;lt;stdio.h&amp;gt;&lt;br /&gt;
#include &amp;lt;conio.h&amp;gt;&lt;br /&gt;
#include &amp;lt;stdlib.h&amp;gt;&lt;br /&gt;
#define MAX 80&lt;br /&gt;
char buf[MAX+1];&lt;br /&gt;
int spos = 0;&lt;br /&gt;
int rpos = 0;&lt;br /&gt;
void qstore(char q);&lt;br /&gt;
char qretrieve(void);&lt;br /&gt;
int main(void)&lt;br /&gt;
{&lt;br /&gt;
  register char ch;&lt;br /&gt;
  int t;&lt;br /&gt;
  buf[80] = &amp;quot;\0&amp;quot;;&lt;br /&gt;
  /* Input characters until a carriage return is typed. */&lt;br /&gt;
  for(ch=&amp;quot; &amp;quot;,t=0; t&amp;lt;32000 &amp;amp;&amp;amp; ch!=&amp;quot;\r&amp;quot;; ++t) {&lt;br /&gt;
    if(_kbhit()) {&lt;br /&gt;
      ch = _getch();&lt;br /&gt;
      qstore(ch);&lt;br /&gt;
    }&lt;br /&gt;
    printf(&amp;quot;%d &amp;quot;, t);&lt;br /&gt;
    if(ch == &amp;quot;\r&amp;quot;) {&lt;br /&gt;
      /* Display and empty the key buffer. */&lt;br /&gt;
      printf(&amp;quot;\n&amp;quot;);&lt;br /&gt;
      while((ch=qretrieve()) != &amp;quot;\0&amp;quot;) printf(&amp;quot;%c&amp;quot;, ch);&lt;br /&gt;
      printf(&amp;quot;\n&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
/* Store characters in the queue. */&lt;br /&gt;
void qstore(char q)&lt;br /&gt;
{&lt;br /&gt;
  if(spos+1==rpos || (spos+1==MAX &amp;amp;&amp;amp; !rpos)) {&lt;br /&gt;
    printf(&amp;quot;List Full\n&amp;quot;);&lt;br /&gt;
    return;&lt;br /&gt;
  }&lt;br /&gt;
  buf[spos] = q;&lt;br /&gt;
  spos++;&lt;br /&gt;
  if(spos==MAX) spos = 0; /* loop back */&lt;br /&gt;
}&lt;br /&gt;
/* Retrieve a character. */&lt;br /&gt;
char qretrieve(void)&lt;br /&gt;
{&lt;br /&gt;
  if(rpos==MAX) rpos = 0; /* loop back */&lt;br /&gt;
  if(rpos==spos) return &amp;quot;\0&amp;quot;;&lt;br /&gt;
  rpos++;&lt;br /&gt;
  return buf[rpos-1];&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Queue in C==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;string.h&amp;gt;&lt;br /&gt;
#include &amp;lt;stdlib.h&amp;gt;&lt;br /&gt;
#include &amp;lt;stdio.h&amp;gt;&lt;br /&gt;
#include &amp;lt;ctype.h&amp;gt;&lt;br /&gt;
#define MAX 100&lt;br /&gt;
char *p[MAX], *pop(void);&lt;br /&gt;
int spos = 0;&lt;br /&gt;
int rpos = 0;&lt;br /&gt;
void add(void), push(char *q), print(void), remove(void);&lt;br /&gt;
&lt;br /&gt;
void add(void)&lt;br /&gt;
{&lt;br /&gt;
  char s[256], *p;&lt;br /&gt;
  do {&lt;br /&gt;
    printf(&amp;quot;spos %d: &amp;quot;, spos+1);&lt;br /&gt;
    gets(s);&lt;br /&gt;
    if(*s==0) {&lt;br /&gt;
       break;&lt;br /&gt;
    }&lt;br /&gt;
    p = (char *) malloc(strlen(s)+1);&lt;br /&gt;
    if(!p) {&lt;br /&gt;
      printf(&amp;quot;Out of memory.\n&amp;quot;);&lt;br /&gt;
      return;&lt;br /&gt;
    }&lt;br /&gt;
    strcpy(p, s);&lt;br /&gt;
    if(*s) {&lt;br /&gt;
       push(p);&lt;br /&gt;
    }&lt;br /&gt;
  } while(*s);&lt;br /&gt;
}&lt;br /&gt;
void print(void)&lt;br /&gt;
{&lt;br /&gt;
  int t;&lt;br /&gt;
  for(t=rpos; t &amp;lt; spos; ++t)&lt;br /&gt;
    printf(&amp;quot;%d. %s\n&amp;quot;, t+1, p[t]);&lt;br /&gt;
}&lt;br /&gt;
void remove(void)&lt;br /&gt;
{&lt;br /&gt;
  char *p;&lt;br /&gt;
  if((p=pop())==NULL) {&lt;br /&gt;
     return;&lt;br /&gt;
  }&lt;br /&gt;
  printf(&amp;quot;%s\n&amp;quot;, p);&lt;br /&gt;
}&lt;br /&gt;
void push(char *q)&lt;br /&gt;
{&lt;br /&gt;
  if(spos==MAX) {&lt;br /&gt;
    printf(&amp;quot;List Full\n&amp;quot;);&lt;br /&gt;
    return;&lt;br /&gt;
  }&lt;br /&gt;
  p[spos] = q;&lt;br /&gt;
  spos++;&lt;br /&gt;
}&lt;br /&gt;
char *pop(void)&lt;br /&gt;
{&lt;br /&gt;
  if(rpos==spos) {&lt;br /&gt;
    printf(&amp;quot;No more.\n&amp;quot;);&lt;br /&gt;
    return NULL;&lt;br /&gt;
  }&lt;br /&gt;
  rpos++;&lt;br /&gt;
  return p[rpos-1];&lt;br /&gt;
}&lt;br /&gt;
int main(void)&lt;br /&gt;
{&lt;br /&gt;
  char s[80];&lt;br /&gt;
  register int t;&lt;br /&gt;
  for(t=0; t &amp;lt; MAX; ++t) {&lt;br /&gt;
     p[t] = NULL;&lt;br /&gt;
  }&lt;br /&gt;
  while(1) {&lt;br /&gt;
    printf(&amp;quot;Add(A), Print(P), Remove(R), Quit(Q): &amp;quot;);&lt;br /&gt;
    gets(s);&lt;br /&gt;
    *s = toupper(*s);&lt;br /&gt;
    switch(*s) {&lt;br /&gt;
      case &amp;quot;A&amp;quot;:&lt;br /&gt;
        add();&lt;br /&gt;
        break;&lt;br /&gt;
      case &amp;quot;P&amp;quot;:&lt;br /&gt;
        print();&lt;br /&gt;
        break;&lt;br /&gt;
      case &amp;quot;R&amp;quot;:&lt;br /&gt;
        remove();&lt;br /&gt;
        break;&lt;br /&gt;
      case &amp;quot;Q&amp;quot;:&lt;br /&gt;
        exit(0);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>