自己写的一个简单的队列类

 1 #pragma once

 3 #include<stdio.h>
 4 #include<stdlib.h>
 5 #include<iostream>
 6 
 7 class CStack
 8 {
 9 public:
10     CStack();
11     ~CStack();
12 public:
13     typedef struct QUEUE
14     {
15         int nHead;            //队头
16         int nTail;            //队尾
17         double* dbData;        //数据
18     };
19 
20     QUEUE m_queue;
21 
22     int m_nQueueSize;
23 
24 public:
25     bool SetFree();
26     bool SetArraySize(int nSize);
27     bool PutValue(double dbValue);
28     bool PopValue();
29     bool IsEmpty();
30     bool IsFull();
31 
32     int Size();
33     
34     double GetValue(int nPos);
35 };


//实现文件

#include "stack.h"

CStack::CStack()
{
    m_queue.nHead = 0;
    m_queue.nTail = -1;
}

CStack::~CStack()
{
}

bool CStack::SetFree()
{
     if(IsEmpty())
    {
        AfxMessageBox(_T("队列已空!"));
         return  false;
    }
     else
    {
        m_queue.nHead = 0;
        m_queue.nTail = -1;
        delete m_queue.dbData;
    }

     return  true;
}

bool CStack::SetArraySize( int nSize)
{
    m_queue.nHead = 0;
    m_queue.nTail = -1;
    m_queue.dbData =  new  double[nSize];

    m_nQueueSize = nSize;

     return  true;
}

bool CStack::PutValue( double dbValue)
{
     if(IsFull())
    {
         for( int i = 0; i < m_nQueueSize -1; i++)
        {
            m_queue.dbData[i +1] = m_queue.dbData[i];
        }
        m_queue.dbData[0] = dbValue;
    }
     else  if(IsEmpty())
    {
        m_queue.nTail++;
        m_queue.dbData[0] = dbValue;
    }
     else
    {
        m_queue.nHead++;
        m_queue.dbData[m_queue.nHead] = dbValue;
    }

     return  true;
}

bool CStack::PopValue()
{
     if(IsEmpty())
    {
        AfxMessageBox(_T("队列已经为空!"));
         return  false;
    }
     else
    {
        m_queue.dbData[m_queue.nHead] = 0;
        m_queue.nHead--;
    }

     return  true;
}

bool CStack::IsEmpty()
{
     if(m_queue.nTail == -1)
         return  true;
     else
         return  false;
}

bool CStack::IsFull()
{
     if(m_queue.nHead - m_queue.nTail >= m_nQueueSize - 1)
         return  true;
     else
         return  false;
}

double CStack::GetValue( int nPos)
{
     if(nPos > m_nQueueSize - 1)
    {
        AfxMessageBox(_T("越界!"));
         return -1;
    }

     double dbValue = m_queue.dbData[nPos];

     return dbValue;
}

int CStack::Size()
{
     if(IsEmpty())
         return 0;

     int nSize = m_queue.nHead - m_queue.nTail +1;

     return nSize;
}

转载于:https://www.cnblogs.com/yangpengsky/archive/2012/07/05/2577746.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值