如何将字符串放入char堆栈并将其打印出来? C

我将一个字符串传递给我的函数,该函数应该使用该字符串将各个字符放入堆栈中.然后堆栈应该将其吐出(因为它是一个堆栈,它应该被反转).例如,如果我的字符串是hello,它应该打印“olleh”.但相反,我得到了ooooo.我认为这与我每次设置ch等于不同的角色这一事实有关,但我不确定如何以不同的方式输入这些角色.

void Stack::function2reverse(string myString) {

    int countItIt = 0;
    int sizeOfString = myString.size();
    char Ch ;
    for (int i= 0; i< sizeOfString; x++)
    {
        Ch = myString[x];
        stack.push(Ch);
        countIt ++;

    }

    while (countIt != 0)
    {    
        cout << Ch;
        stack.pop();
        countIt --;
    }
}

解决方法

cout<< CH; - 每次打印相同的字符(输入的最后一个字符,所以'o'). 相反,打印堆栈中的顶部字符:std :: cout<< stack.top(). std :: stack跟踪自己的 size,所以你也不必担心.然后你可以用以下代码替换你的打印循环

while (!stack.empty()) {
    std::cout << stack.top();
    stack.pop();
}

当然,标准库无论如何都提供了std::reverse功能,所以如果这不仅仅是学习std :: stack的练习,你可以使用它(我可以想到其他一些事情也可以做,具体取决于你想要达到的目的):

std::string s = "hello";
std::reverse(std::begin(s),std::end(s));
// s Now contains "olleh"

您可能还想阅读why using namespace std; is a bad practice.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...