| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 374 人关注过本帖
标题:数据结构问题,如何用两个队列实现栈操作!求大神!
只看楼主 加入收藏
死亡代码
Rank: 1
等 级:新手上路
帖 子:8
专家分:4
注 册:2013-10-11
结帖率:75%
收藏
已结贴  问题点数:10 回复次数:3 
数据结构问题,如何用两个队列实现栈操作!求大神!
栈是先进后出,而队列是先进先出,不知如何用队列实现栈的操作,求各位解答
搜索更多相关主题的帖子: 如何 
2014-04-23 20:59
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
就是把队列做缓存空间

假设有队列 A,B

push: A队列空 就插入B队列,B队列空就插入A队列

pop : A队列空,将B队列中的数据取出存入A队列,直到B 只剩1个数据,再讲这个直接取出;

总之就是这样不停地换


[fly]存在即是合理[/fly]
2014-04-24 22:33
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:10 
写了一下

程序代码:
void pop(Stack *S, ElemType *e)
{
    ElemType tmp;
    if (StackEmpty(*S))  return;

    if (QueueEmpty(S->queue1))
    {
        while (1 < QueueCount(S->queue2))
        {
            DeQueue(&S->queue2, &tmp);
            EnQueue(&S->queue1, tmp);
        }
        DeQueue(&S->queue2, e);
    }
    else
    {
        while (1 < QueueCount(S->queue1))
        {
            DeQueue(&S->queue1, &tmp);
            EnQueue(&S->queue2, tmp);
        }
        DeQueue(&S->queue1, e);
    }
}

void push(Stack *S, ElemType e)
{
    if (StackFill(*S))  return;
    if (QueueEmpty(S->queue1))
    {
        EnQueue(&S->queue2, e);
    }
    else
    {
        EnQueue(&S->queue1, e);
    }
}


[fly]存在即是合理[/fly]
2014-04-24 22:39
死亡代码
Rank: 1
等 级:新手上路
帖 子:8
专家分:4
注 册:2013-10-11
收藏
得分:0 
回复 3 楼 azzbcc
谢了
2014-04-27 18:12
快速回复:数据结构问题,如何用两个队列实现栈操作!求大神!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.035751 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved