鱼C论坛

 找回密码
 立即注册
查看: 1165|回复: 2

[已解决]逆序输出的栈实现

[复制链接]
发表于 2021-7-23 22:12:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
首先看原题
Description
输入一个正整数 a(0\le a\le 10^9)a(0≤a≤10
9
),逆序输出该数(不带前导0)

Format
Input
一个正整数 a(0\le a\le 10^9)a(0≤a≤10
9
)。

Output
逆序输出该数(不带前导0).

这是在OJ上的题,我用栈做的,用OJ提供的编译机算的是0分,用devc++算的是去了零,但没有逆序
我是从高位进栈,输出时从低位出栈并过滤0
代码如下:
#include <iostream>
#include <stack>
using namespace std;

int main()
{
    int a;
    cin>>a;

    stack<int> intes;

    while (a != 0)
    {
        intes.push(a % 10);
        a /= 10;
    }

    while (1)
    {
        bool flag = 0;
        if (intes.top() == 0)
        {
            intes.pop();
            continue;
        }
        if (intes.top() != 0)
        {
            if (flag == 0)
            {
                flag = 1;
            }
            cout<<intes.top();
            intes.pop();
        }
        if (intes.empty())
        {
            break;
        }
    }
    
    return 0;
}
求解答
最佳答案
2021-7-23 22:42:13
#include <iostream>
#include <queue>

using namespace std;

int main()
{
    int a;
    cin>>a;

    queue<int> intes;

    while (a != 0)
    {
        intes.push(a % 10);
        a /= 10;
    }

    bool flag = 0;
    while (1)
    {
        if (intes.front() == 0 && flag == 0)
        {
            intes.pop();
            continue;
        } else {
            if (flag == 0)
            {
                flag = 1;
            }
            cout<<intes.front();
            intes.pop();
        }
        if (intes.empty())
        {
            break;
        }
    }

    std::cout << std::endl;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-7-23 22:39:19 | 显示全部楼层
这个程序应该使用栈吗?
应该使用队列吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-7-23 22:42:13 | 显示全部楼层    本楼为最佳答案   
#include <iostream>
#include <queue>

using namespace std;

int main()
{
    int a;
    cin>>a;

    queue<int> intes;

    while (a != 0)
    {
        intes.push(a % 10);
        a /= 10;
    }

    bool flag = 0;
    while (1)
    {
        if (intes.front() == 0 && flag == 0)
        {
            intes.pop();
            continue;
        } else {
            if (flag == 0)
            {
                flag = 1;
            }
            cout<<intes.front();
            intes.pop();
        }
        if (intes.empty())
        {
            break;
        }
    }

    std::cout << std::endl;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-21 22:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表