数据结构 栈

栈是数据项序列,只能在序列的一端访问这些数据项,可以把栈想象为数据项的集合,这些项一个堆到另一个上,只能访问最上层的项。栈有从栈顶插入和删除项的操作。push () 操作在栈顶位置增加1项。一旦把新项加入栈,就只能看到和访问这个新项。栈中以前的所有项向下移动,看不到它们。pop() 操作从栈中删除1个元素。top() 操作可以用来显示栈顶的元素

#include <iostream>
#include <string>
#include <stack>


using namespace std;


int main()
{
string fistname = "John", lastname = "Doe", fullname;
stack<string> stk;


stk.push(fistname);     // 往栈里添加元素 fistname,lastname
stk.push(lastname);


fullname = stk.top();    // 把栈顶(lastname)赋给fullname
cout << fullname <<endl;    //输出fullname
stk.pop();     //  删除栈stk栈顶元素 lastname
cout << fullname <<endl;    // 即使把栈顶的元素lastname删除了,但fullname里已经赋给了字符串lastname变量,所以,fullname值不变
cout << stk.top() <<endl;     // 栈stk中的lastname变量删除,fistname置栈顶,因此输出 fistname对应的变量
stk.top() = "Jack";      //  栈stk栈顶被赋值为"Jack" 
cout << stk.top() << endl;;  //  所以输出"Jack" 


fullname += "," + stk.top();   //字符串中的“+”加号是在字符串的后面添加字符串
cout << fullname <<endl;
stk.pop();
return 0;

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值