注册 登录
编程论坛 数据结构与算法

请问如何用C++语言来实现栈的操作?

shujujiegou1 发布于 2012-10-10 21:08, 401 次点击
新手,刚接触数据结构,觉得太难了,什么也不懂,求各位大哥大姐能否介绍几本适合初学者用的书,在此感激不尽!
5 回复
#2
chao199102102012-10-11 14:05
我也刚学数据结构,刚开始觉得很抽象,然后再图书馆找了一本《数据结构》(c/c++描述)是朱承学和李锡辉的,现在虽然看的时间不长,但是收获蛮大的。其实你完全可以自己去找一些带有例子的书去看,自己动手写写,相信你会有收获的。
#3
寒风中的细雨2012-10-11 18:57
回复 2楼 chao19910210
支持。。。
#4
pangding2012-10-12 13:30
嗯。很多书里都有例子,多看看,想懂了再试着自己实现。
#5
月下美人_952012-10-16 22:00
/**************************
    以下前几天封装的栈模版
    你可以参考一下
**************************/
#ifndef _STACK_H_
#define _STACK_H_

#include <stdlib.h>
#include <stdio.h>
#include <iostream.h>

template <class T>
class CStack
{
public:
    CStack();
    explicit CStack(int iNum);
    CStack(CStack &);
    ~CStack();

    void push(T data);
    T peek();
    T pop();

    void appendCapacity();//用来追加栈的容量   
    int getNumberOfelement()//返回栈中元素的个数
    {
        return numberOfelement;
    }
private:
    T *ptrOfele;//指向动态创建的数组,用模板参数T取代具体类型
    int capacity;//栈的容量
    int numberOfelement;//栈中元素个数
};

template <class T>
CStack<T>::CStack()
{
    capacity = 10;
    numberOfelement = 0;
    ptrOfele = new T[capacity];
}

template <class T>
CStack<T>::CStack(int iNum)
{
    capacity = iNum;
    numberOfelement = 0;
    ptrOfele = new T[capacity];
}

template <class T>
CStack<T>::~CStack()
{
    delete []ptrOfele;
}

template <class T>
void CStack<T>::push(T data)
{
    if (numberOfelement < capacity)
    {
        ptrOfele[numberOfelement++] = data;
    }
    else
        this->appendCapacity();
}

template <class T>
T CStack<T>::peek()
{
    if (numberOfelement > 0)
        return ptrOfele[numberOfelement];
}

template <class T>
T CStack<T>::pop()
{
    if (numberOfelement > 0)
        return ptrOfele[--numberOfelement];
}

template <class T>
void CStack<T>::appendCapacity()
{
    capacity += 10;
    T *ptrTmp = new T[capacity];
    for (int i = 0; i<capacity-10; i++)
    {
        ptrTmp[i] = ptrOfele[i];
    }
    delete [] ptrOfele;
    ptrOfele = ptrTmp;
}

#endif
#6
zhu2240392012-10-17 00:08
看伪代码才是王道

如果木有了例子  我看你怎么办
还是学着看伪代码的好
万能的 ,跟语言没关系
1