3.3 栈就像叠盘子,当盘子叠得太高时,就会倾斜倒下。因此,在真实的世界中,当一叠盘子 (栈)超过了一定的高度时,我们就会另起一堆,再从头叠起。实现数据结构SetOfStacks 来模拟这种情况。SetOfStacks由几个栈组成,当前一栈超出容量时,需要创建一个新的栈 来存放数据。SetOfStacks.push()和SetOfStacks.pop()的行为应当和只有一个栈时 表现的一样。

进一步地,

实现函数popAt(int index)在指定的子栈上进行pop操作。

实现第一步:

#include<iostream>
#include<new>
using namespace std; //myStack表示一个栈
class myStack
{
private:
int *buf;
int capacity;
int cur;
public:
myStack(int size=)
{
buf=new int[size];
capacity=size;
cur=-;
}
~myStack()
{
delete[] buf;
}
void push(int x)
{
buf[++cur]=x;
}
void pop()
{
cur--;
}
int top()
{
return buf[cur];
}
bool empty()
{
return cur==-;
}
bool full()
{
return cur==capacity-;
}
}; //一个栈组成的数组
class SetOfStacks
{
private:
myStack *st;
int cur;
int capacity;
public:
SetOfStacks(int cap=)
{
st=new myStack[cap];
capacity=cap;
cur=;
}
~SetOfStacks()
{
delete[] st;
}
void push(int x)
{
if(st[cur].full())
cur++;
if(cur>capacity-)
return;
st[cur].push(x);
}
void pop()
{
if(st[cur].empty())
cur--;
if(cur<)
return;
st[cur].pop();
}
int top()
{
if(st[cur].empty())
cur--;
if(cur<)
return ;
else
return st[cur].top();
}
bool empty()
{
return cur==&&st[cur].empty();
}
bool full()
{
return cur==capacity-&&st[cur].full();
}
};
int main()
{
SetOfStacks ss1;
for(int i=; i<*+; ++i)
{
ss1.push(i);
}
while(!ss1.empty())
{
cout<<ss1.top()<<endl;
ss1.pop();
}
return ;
}

当加入popAt函数,情况就变得复杂了。因为这时候的数据分布可能出现中间的某些子栈使 用popAt把它们清空了,而后面的子栈却有数据。为了实现方便,我们不考虑因为popAt 带来的空间浪费。即如果我用popAt把中间某些子栈清空了,并不把后面子栈的数据往前移 动。这样一来,cur指向操作的“最后”一个栈,它后面的子栈一定都是空的, 而它本身及前面的子栈由于popAt函数的缘故都有可能是空的。如果没有popAt函数, cur前面的子栈一定都是满的(见上面的例子)。这样一来,push仍然只需要判断一次当前子 栈是否为满。但是,pop函数则要从cur向前一直寻找,直到找到一个非空的子栈, 才能进行pop操作。同理,popAt,top,empty也是一样的。

#include<iostream>
#include<new>
using namespace std; //myStack表示一个栈
class myStack
{
private:
int *buf;
int capacity;
int cur;
public:
myStack(int size=)
{
buf=new int[size];
capacity=size;
cur=-;
}
~myStack()
{
delete[] buf;
}
void push(int x)
{
buf[++cur]=x;
}
void pop()
{
cur--;
}
int top()
{
return buf[cur];
}
bool empty()
{
return cur==-;
}
bool full()
{
return cur==capacity-;
}
}; //一个栈组成的数组
class SetOfStacks
{
private:
myStack *st;
int cur;
int capacity;
public:
SetOfStacks(int cap=)
{
st=new myStack[cap];
capacity=cap;
cur=;
}
~SetOfStacks()
{
delete[] st;
}
void push(int x)
{
if(st[cur].full())
cur++;
if(cur>capacity-)
return;
st[cur].push(x);
}
void pop()
{
while(st[cur].empty())
cur--;
if(cur<)
return;
st[cur].pop();
}
int top()
{
while(st[cur].empty())
cur--;
if(cur<)
return ;
else
return st[cur].top();
}
bool empty()
{
while(cur>=&&st[cur].empty())
cur--;
return cur==-;
}
bool full()
{
return cur==capacity-&&st[cur].full();
}
void popAt(int idx)
{
while(st[idx].empty()) --idx;
st[idx].pop();
}
};
int main()
{
SetOfStacks ss1;
for(int i=; i<*+; ++i)
{
ss1.push(i);
}
for(int i=; i<; ++i)
{
ss1.popAt();
//ss1.popAt(1);
ss1.popAt();
}
while(!ss1.empty())
{
cout<<ss1.top()<<endl;
ss1.pop();
}
return ;
}

careercup-栈与队列 3.3的更多相关文章

  1. 学习javascript数据结构(一)——栈和队列

    前言 只要你不计较得失,人生还有什么不能想法子克服的. 原文地址:学习javascript数据结构(一)--栈和队列 博主博客地址:Damonare的个人博客 几乎所有的编程语言都原生支持数组类型,因 ...

  2. [ACM训练] 算法初级 之 数据结构 之 栈stack+队列queue (基础+进阶+POJ 1338+2442+1442)

    再次面对像栈和队列这样的相当基础的数据结构的学习,应该从多个方面,多维度去学习. 首先,这两个数据结构都是比较常用的,在标准库中都有对应的结构能够直接使用,所以第一个阶段应该是先学习直接来使用,下一个 ...

  3. 剑指Offer面试题:6.用两个栈实现队列

    一.题目:用两个栈实现队列 题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能. 原文是使用 ...

  4. C实现栈和队列

    这两天再学习了数据结构的栈和队列,思想很简单,可能是学习PHP那会没有直接使用栈和队列,写的太少,所以用具体代码实现的时候出现了各种错误,感觉还是C语言功底不行.栈和队列不论在面试中还是笔试中都很重要 ...

  5. JavaScript数组模拟栈和队列

    *栈和队列:js中没有真正的栈和队列的类型              一切都是用数组对象模拟的 栈:只能从一端进出的数组,另一端封闭       FILO   何时使用:今后只要仅希望数组只能从一端进 ...

  6. 用JS描述的数据结构及算法表示——栈和队列(基础版)

    前言:找了上课时数据结构的教程来看,但是用的语言是c++,所以具体实现在网上搜大神的博客来看,我看到的大神们的博客都写得特别好,不止讲了最基本的思想和算法实现,更多的是侧重于实例运用,一边看一边在心里 ...

  7. JavaScript中的算法之美——栈、队列、表

    序 最近花了比较多的时间来学习前端的知识,在这个期间也看到了很多的优秀的文章,其中Aaron可能在这个算法方面算是我的启蒙,在此衷心感谢Aaron的付出和奉献,同时自己也会坚定的走前人这种无私奉献的分 ...

  8. Java数据结构和算法之栈与队列

    二.栈与队列 1.栈的定义 栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表. (1)通常称插入.删除的这一端为栈顶(Top),另一端称为栈底(Bottom). (2)当表中没有元素时称为 ...

  9. python数据结构之栈、队列的实现

    这个在官网中list支持,有实现. 补充一下栈,队列的特性: 1.栈(stacks)是一种只能通过访问其一端来实现数据存储与检索的线性数据结构,具有后进先出(last in first out,LIF ...

  10. 栈和队列的面试题Java实现【重要】

    栈和队列: 面试的时候,栈和队列经常会成对出现来考察.本文包含栈和队列的如下考试内容: (1)栈的创建 (2)队列的创建 (3)两个栈实现一个队列 (4)两个队列实现一个栈 (5)设计含最小函数min ...

随机推荐

  1. What is machine learning?

    What is machine learning? One area of technology that is helping improve the services that we use on ...

  2. 设计模式之装饰(Decorator)模式 代码详解

    /** * Created with IntelliJ IDEA. * User: HYY * Date: 13-10-27 * Time: 下午10:49 * To change this temp ...

  3. 【BZOJ 2005】[Noi2010]能量采集 (容斥原理| 欧拉筛+ 分块)

    能量采集 Description 栋栋有一块长方形的地,他在地上种了一种能量植物,这种植物可以采集太阳光的能量.在这些植物采集能量后,栋栋再使用一个能量汇集机器把这些植物采集到的能量汇集到一起. 栋栋 ...

  4. http://blog.csdn.net/dyllove98/article/details/7706218

    http://blog.csdn.net/dyllove98/article/details/7706218

  5. 李洪强漫谈iOS开发[C语言-025]-赋值运算符案例

  6. C++控制台程序中使用定时器

    转自博客:http://www.cnblogs.com/phinecos/archive/2008/03/08/1096691.html 作者:洞庭散人 “我现在项目是一个控制台程序,用到的Win32 ...

  7. Application对象的使用-数据传递以及内存泄漏

    Application的使用 What is Application Application和Activity,Service一样是android框架的一个系统组件,当android程序启动时系统会创 ...

  8. 两个有关Knockout自定义拓展方法fn的小技巧

    Adding custom functions using "fn" 让observable自增/自减 最简单的方法是self.num(self.num() + 1), 但是这个写 ...

  9. JMS的作用

    JMS就是生产者与消费者模式.消费者负责消费生产者产生的消息.通过JMS可以做后台的异步操作,应用到具体工作中的话,有用它来发内部消息的.发邮件的.发短信的,做大操作时在后台做异步操作的. Java ...

  10. Linux协议栈函数调用流程

    普通网络驱动程序中必须要调用的函数是eth_type_trans(略),然后向上递交sk_buff时调用netif_rx()(net/core/dev.c).其函数中主要几行 __skb_queue_ ...