<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=DataStructure%2FQueue</id>
	<title>DataStructure/Queue - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=DataStructure%2FQueue"/>
	<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=DataStructure/Queue&amp;action=history"/>
	<updated>2026-05-15T12:37:26Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.8</generator>
	<entry>
		<id>https://mediawiki.zeropage.org/index.php?title=DataStructure/Queue&amp;diff=31156&amp;oldid=prev</id>
		<title>imported&gt;Unknown at 05:23, 7 February 2021</title>
		<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=DataStructure/Queue&amp;diff=31156&amp;oldid=prev"/>
		<updated>2021-02-07T05:23:05Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;__TOC__&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
= Queue =&lt;br /&gt;
* Queue는 나중에 넣은 것은 나중에 나오고 먼저 넣은 것은 먼저 나오는 자료 구조입니다.&lt;br /&gt;
* 위 아래 뻥 뚫린.. 위로 물부으면 밑으로 나오겠죠? (먼저 들어간건 먼저 나온다!)&lt;br /&gt;
* 자판기를 생각하면 되겟죠? 먼저 선 사람이 먼저 나가니..(새-_-치기 제외)&lt;br /&gt;
* Front는 큐의 맨 앞을 가르키는 변수, Rear는 큐의 맨 끝 원소를 가르키는 변수&lt;br /&gt;
&lt;br /&gt;
== 배열로 구현한 Queue ==&lt;br /&gt;
 class Queue&lt;br /&gt;
 {&lt;br /&gt;
 	enum {Size=100};&lt;br /&gt;
 private:&lt;br /&gt;
 	int m_nFront;&lt;br /&gt;
 	int m_nRear;&lt;br /&gt;
 	int m_nData[Size];&lt;br /&gt;
 	bool IsEmpty();&lt;br /&gt;
 	bool IsFull();&lt;br /&gt;
 public:&lt;br /&gt;
 	Queue() {m_nFront=m_nRear=-1;}&lt;br /&gt;
 	bool Add(int ndata);&lt;br /&gt;
 	bool Erase();&lt;br /&gt;
 	void Show();&lt;br /&gt;
 	~Queue() {}&lt;br /&gt;
 };&lt;br /&gt;
 &lt;br /&gt;
 bool Queue::IsEmpty()&lt;br /&gt;
 {&lt;br /&gt;
 &lt;br /&gt;
 true;&lt;br /&gt;
 	return false;&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 bool Queue::IsFull()&lt;br /&gt;
 {&lt;br /&gt;
 	if(m_nRear==Size-1 &amp;amp;amp;&amp;amp;amp; m_nFront!=m_nRear)&lt;br /&gt;
 		return true;&lt;br /&gt;
 	return false;&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 bool Queue::Add(int ndata)&lt;br /&gt;
 {&lt;br /&gt;
 	if(!IsFull())&lt;br /&gt;
 	{&lt;br /&gt;
 		m_nData[++m_nRear]=ndata;&lt;br /&gt;
 		return true;&lt;br /&gt;
 	}&lt;br /&gt;
 	else&lt;br /&gt;
 	{&lt;br /&gt;
 		cout&amp;amp;lt;&amp;amp;lt;&amp;quot;꽉찼다&amp;quot;;&lt;br /&gt;
 		return false;&lt;br /&gt;
 	}&lt;br /&gt;
 }&lt;br /&gt;
 	&lt;br /&gt;
 bool Queue::Erase()&lt;br /&gt;
 {&lt;br /&gt;
 	if(!IsEmpty())&lt;br /&gt;
 	{&lt;br /&gt;
 		m_nFront++;&lt;br /&gt;
 		return true;&lt;br /&gt;
 	}&lt;br /&gt;
 	else&lt;br /&gt;
 	{&lt;br /&gt;
 		cout&amp;amp;lt;&amp;amp;lt;&amp;quot;비었다&amp;quot;;&lt;br /&gt;
 		return false;&lt;br /&gt;
 	}&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 void Queue::Show()&lt;br /&gt;
 {&lt;br /&gt;
 	int count=m_nFront;&lt;br /&gt;
 	while(1)&lt;br /&gt;
 	{&lt;br /&gt;
 		cout&amp;amp;lt;&amp;amp;lt;m_nData[++count];&lt;br /&gt;
 		if(count==m_nRear)&lt;br /&gt;
 			break;&lt;br /&gt;
 	}&lt;br /&gt;
 }&lt;br /&gt;
&lt;br /&gt;
* 그런데.. 이 큐는 문제점이 있습니다. &lt;br /&gt;
* 원소를 한 90개 넣고 그 원소를 90개 다지우면? Front와 Rear가 각각 89를 가리키게 되겠지요? 그럼 남는 공간은 10-_-개밖에 안됩니다.&lt;br /&gt;
* 이렇게 되면 첨에 100개의 배열을 할당해준것중에 90개를 못 쓰게 되겠네요.&lt;br /&gt;
* 이를 보완하기 위해 원형 큐라는게 있더랍니다. 또는 링크드 리스트로 큐를 만들어서 제한없이 쓰는 방법도 있겠죠.&lt;br /&gt;
* 요것도 만들어봐야겠죠?^^&lt;br /&gt;
&lt;br /&gt;
== Linked List로 만든 큐 ==&lt;br /&gt;
 class Queue&lt;br /&gt;
 {&lt;br /&gt;
 private:&lt;br /&gt;
 	struct Node&lt;br /&gt;
 	{&lt;br /&gt;
 		int nData;&lt;br /&gt;
 		Node* pPrev;&lt;br /&gt;
 	};&lt;br /&gt;
 	Node* m_pFront;&lt;br /&gt;
 	Node* m_pRear;&lt;br /&gt;
 	bool IsEmpty();&lt;br /&gt;
 public:&lt;br /&gt;
 	Queue();&lt;br /&gt;
 	~Queue();&lt;br /&gt;
 	void Add(int x);&lt;br /&gt;
 	void Remove();&lt;br /&gt;
 };&lt;br /&gt;
 &lt;br /&gt;
 Queue::Queue()&lt;br /&gt;
 {&lt;br /&gt;
 	m_pFront=new Node;&lt;br /&gt;
 	m_pFront-&amp;amp;gt;pPrev=NULL;&lt;br /&gt;
 	m_pRear=m_pFront;&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 void Queue::Add(int x)&lt;br /&gt;
 {&lt;br /&gt;
 	Node* temp=new Node;&lt;br /&gt;
 	temp-&amp;amp;gt;nData=x;&lt;br /&gt;
 	temp-&amp;amp;gt;pPrev=m_pRear;&lt;br /&gt;
 	m_pRear=temp;&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 void Queue::Remove()&lt;br /&gt;
 {&lt;br /&gt;
 	if(!IsEmpty())&lt;br /&gt;
 	{&lt;br /&gt;
 		Node* temp=m_pRear-&amp;amp;gt;pPrev;&lt;br /&gt;
 		delete m_pRear;&lt;br /&gt;
 		m_pRear=temp;&lt;br /&gt;
 	}&lt;br /&gt;
 	else&lt;br /&gt;
 		cout&amp;amp;lt;&amp;amp;lt;&amp;quot;...&amp;quot;;&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 bool Queue::IsEmpty()&lt;br /&gt;
 {&lt;br /&gt;
 	if(m_pRear==m_pFront)&lt;br /&gt;
 		return true;&lt;br /&gt;
 	else&lt;br /&gt;
 		return false;&lt;br /&gt;
 }&lt;br /&gt;
 &lt;br /&gt;
 Queue::~Queue()&lt;br /&gt;
 {&lt;br /&gt;
 	while(!IsEmpty())&lt;br /&gt;
 	{&lt;br /&gt;
 		Remove();&lt;br /&gt;
 	}&lt;br /&gt;
 	delete m_pFront;&lt;br /&gt;
 }&lt;br /&gt;
&lt;/div&gt;</summary>
		<author><name>imported&gt;Unknown</name></author>
	</entry>
</feed>