cpp stack【学习用】

参考:cpp stack 官方解释描述

(不全)

LIFO (last-in first-out) stack 后入先出栈
堆栈是一种容器适配器,专门设计用于在 LIFO 上下文(后进先出)中操作,其中元素仅从容器的一端插入和提取。
堆栈被实现为容器适配器,这些类使用特定容器类的封装对象作为其底层容器,提供一组特定的成员函数来访问其元素。 元素从特定容器的“后部”(称为堆栈的顶部)推送/弹出 push/pop

Member functions 成员函数

top - Access next element 获取下一个元素

      value_type& top();
const value_type& top() const;

返回对栈顶元素的引用。

由于堆栈是后进先出容器,因此顶部元素是插入堆栈的最后一个元素。

这个成员函数有效地调用了底层容器对象的成员。

Example:

// stack::top
#include <iostream>
#include <stack>

int main(){
	std::stack<int> mystack;
	
	mystack.push(10);
	mystack.push(20);

	mystack.top() -= 5;

	std::cout << "mystack.top() is now " << mystack.top() << '\n' ;

	return 0;
}

运行结果:mystack.top() is now 15

push - Insert element 插入元素

void push (const value_type& val); // val: 插入元素的初始化值

在堆栈顶部插入一个新元素,在其当前顶部元素上方。 这个新元素的内容被初始化为 val 的副本。

这个成员函数有效地调用了底层容器对象的成员函数 push_back。

Example:

// stack::push/pop
#include <iostream>
#include <stack>

int main(){
	std::stack<int> mystack;

	for(int i=0 ; i<5 ; ++i )
		mystack.push(i);
	std::cout << "Popping out elements..." ;
	while(!mystack.empty()){
		std::cout << ' ' << mystack.top();
		mystack.pop();
	}
	std::cout << '\n' ;

	return 0;
}

运行结果:Popping out elements… 4 3 2 1 0

pop - Remove top element 移除栈顶元素

void pop();

删除堆栈顶部的元素,有效地将其大小减一。

移除的元素是最新插入堆栈的元素,其值可以通过调用成员 stack::top 来检索。

这会调用被移除元素的析构函数。

这个成员函数有效地调用了底层容器对象的成员函数 pop_back。

Example:
参见上文 push 的例子。

size - Return size 返回栈中元素数目

size_type size() const;

返回堆栈中的元素数。

这个成员函数有效地调用了底层容器对象的成员 size。

Example:

// stack::size
#include <iostream>
#include <stack>

int main(){
	std::stack<int> myints;
	std::cout << "0. size: " << myints.size() << '\n' ;

	for(int i=0; i<5 ; i++)
		myints.push(i);
	std::cout << "1. size: " << myints.size() << '\n' ;

	myints.pop();
	std::cout << "2. size: " << myints.size() << '\n' ;

	return 0;
}

运行结果:
0. size: 0
1. size: 5
2. size: 4

empty - Test whether container is empty 测试容器是否为空

bool empty() const;

返回堆栈是否为空:即其大小是否为零。

这个成员函数有效地调用了底层容器对象的成员 empty。

返回值:为空,返回 true;不为空,返回 false.

Example:

// stack::empty
#include <iostream>
#include <stack>

int main(){
	std::stack<int> mystack;
	int sum (0);
	
	for(int i=1; i<=10 ; i++)
		mystack.push(i);

	while(!mystack.empty()){
		sum += mystack.top();
		mystack.pop();
	}

	std::cout << "total: " << sum << '\n' ;

	return 0;
}

运行结果:total: 55

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ STL是C++标准模板库(Standard Template Library)的简称。它是C++的一个重要组成部分,提供了一系列的通用模板类和函数,用于处理常见的数据结构和算法问题。 学习C++ STL有以下几个方面的好处: 1. 提高开发效率:STL提供了大量现成的数据结构和算法,比如向量(vector)、链表(list)、队列(queue)、堆栈(stack)等,以及排序、查找、计数、遍历等算法。使用STL可以避免重复造轮子的过程,通过简单的调用就可以快速编写高效的代码,提高开发效率。 2. 提高代码质量:STL是由专业的C++程序员设计和实现的,其设计遵循了面向对象的思想,并使用了模板元编程等技术。使用STL可以提高代码的模块化程度,减少重复代码,使代码更加清晰、简洁和可维护。 3. 为学习其他编程语言打下基础:STL采用了一种通用、抽象的设计,其思想和理念对于学习其他编程语言也是有借鉴意义的。通过学习STL,可以更好地理解数据结构和算法的设计与实现,为学习其他编程语言打下坚实的基础。 要学习C++ STL,可以从以下几个方面入手: 1. 理解STL的组成部分:了解STL的组成部分,包括容器(container)、迭代器(iterator)、算法(algorithm)、函数对象(function object)、适配器(adapter)等。理解它们之间的关系和作用,掌握各个组成部分的用法和特点。 2. 学习STL的常用容器和算法:熟悉STL提供的常用容器和算法,如向量(vector)、链表(list)、队列(queue)、堆栈(stack)等,以及排序、查找、计数、遍历等算法。了解其基本的操作和用法,掌握它们的时间复杂度和使用场景。 3. 理解STL内部实现原理:了解STL内部的实现原理,包括对容器和算法的底层实现,例如迭代器的实现、算法的实现方式和优化等。理解这些原理有助于更好地理解和使用STL,以及优化代码性能。 总之,学习C++ STL对于提高C++编程能力和开发效率非常重要。通过学习STL,可以更好地掌握C++的数据结构和算法,提高代码质量和可维护性,为进一步学习和应用其他编程语言打下坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值