c++ STL容器 --- 栈stack

包含头文件<stack> 

stack<int> intStack;    //创建一个栈
  • 特定的容器处理特定的问题---栈存数据,取数据的方式固定---先进后出---穿脱原则---穿在里面的最后脱

  • 栈的内存会自动增加,不需要考虑内存

  • 寻路算法中常用

  • 没有提供指定位置删除、插入这样的接口

  • 没有迭代器,这个容器可以当作适配器

void testStack() 
{ 
	//1 2 3      插入顺序
	//3 2 1      出栈顺序
	//push(data) 入栈,参数:入的元素
	//pop()      删除,出栈
	//top()      获取栈顶元素,返回元素
	stack<int> intStack;    
	for (int i = 0; i < 3; i++) 
	{
		intStack.push(i);                 //入栈 0 1 2
	}
	while (!intStack.empty())             //判断当前栈是否为空
	{
		cout << intStack.top() << "\t";   //获取栈顶元素
		intStack.pop();                   //不断出栈
	}
	cout << endl;
}

int main() 
{
	testStack();
	return 0;
}
/*输出*/

2    1    0

用栈实现进制转换 7 转 2 进制

void NumTobinary(int data)      //用栈实现把一个数字转为二进制,然后输出
{
	stack<int> bin;
	while (data)                //当data!=0时,余数入栈
	{
		bin.push(data % 2);
		data = data / 2;        //不断整除
	}
	if (bin.size() < 8)         //补齐8位(补高位)
	{
		for (int i = bin.size(); i < 8; i++) 
		{
			bin.push(0);
		}
	}
//不断出栈
	while (!bin.empty()) 
	{
		cout << bin.top();
		bin.pop();
	}
	cout << endl;
}
int main()
{
    NumTobinary(7);
}
/* 补齐8位,根据size判断,不足8位入0 */

/*输出*/
00000111
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qiuqiuyaq

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值