没有合适的资源?快使用搜索试试~ 我知道了~
主要介绍了C++使用一个栈实现另一个栈的排序算法,结合实例形式分析了C++借助辅助栈实现栈排序算法的相关操作技巧,需要的朋友可以参考下
资源推荐
资源详情
资源评论
C++使用一个栈实现另一个栈的排序算法示例使用一个栈实现另一个栈的排序算法示例
主要介绍了C++使用一个栈实现另一个栈的排序算法,结合实例形式分析了C++借助辅助栈实现栈排序算法的相
关操作技巧,需要的朋友可以参考下
本文实例讲述了C++用一个栈实现另一个栈的排序算法。分享给大家供大家参考,具体如下:
题目:题目:
一个栈中元素类型为整型,现在想将该栈从顶到底按从小到大的顺序排序,只许申请一个辅助栈。
除此之外,可以申请新的变量,但不能申请额外的数据结构。如何完成排序?
算法算法C++代码:代码:
class Solution
{
public:
//借助一个临时栈排序源栈
static void sortStackByStack(stack<int>& s)
{
stack<int>* sTemp = new stack<int>;
while (!s.empty())
{
int cur = s.top();
s.pop();
//当源栈中栈顶元素大于临时栈栈顶元素时,将临时栈中栈顶元素放回源栈
//保证临时栈中元素自底向上从大到小
while (!sTemp->empty() && cur > sTemp->top())
{
int temp = sTemp->top();
sTemp->pop();
s.push(temp);
}
sTemp->push(cur);
}
//将临时栈中的元素从栈顶依次放入源栈中
while (!sTemp->empty())
{
int x = sTemp->top();
sTemp->pop();
s.push(x);
}
}
};
测试用例程序:测试用例程序:
#include <iostream>
#include <stack>
using namespace std;
class Solution
{
public:
//借助一个临时栈排序源栈
static void sortStackByStack(stack<int>& s)
{
stack<int>* sTemp = new stack<int>;
while (!s.empty())
{
int cur = s.top();
s.pop();
//当源栈中栈顶元素大于临时栈栈顶元素时,将临时栈中栈顶元素放回源栈
//保证临时栈中元素自底向上从大到小
while (!sTemp->empty() && cur > sTemp->top())
{
int temp = sTemp->top();
sTemp->pop();
s.push(temp);
}
sTemp->push(cur);
}
//将临时栈中的元素从栈顶依次放入源栈中
while (!sTemp->empty())
{
int x = sTemp->top();
sTemp->pop();
资源评论
weixin_38663526
- 粉丝: 3
- 资源: 940
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功