如何将字符串放入char堆栈并将其打印出来? C
发布时间:2020-12-16 10:01:57 所属栏目:百科 来源:网络整理
导读:我将一个字符串传递给我的函数,该函数应该使用该字符串将各个字符放入堆栈中.然后堆栈应该将其吐出(因为它是一个堆栈,它应该被反转).例如,如果我的字符串是hello,它应该打
我将一个字符串传递给我的函数,该函数应该使用该字符串将各个字符放入堆栈中.然后堆栈应该将其吐出(因为它是一个堆栈,它应该被反转).例如,如果我的字符串是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::string s = "hello"; std::reverse(std::begin(s),std::end(s)); // s now contains "olleh" 您可能还想阅读why (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |