From a8afc963b6f6a9b6998b84d998226a6aeb7ffc4c Mon Sep 17 00:00:00 2001 From: Yudong Jin Date: Mon, 28 Nov 2022 20:51:12 +0800 Subject: [PATCH] Update PrintUtil.hpp Reverse the stack before printing. --- codes/cpp/include/PrintUtil.hpp | 44 ++++++++++++++++----------------- 1 file changed, 21 insertions(+), 23 deletions(-) diff --git a/codes/cpp/include/PrintUtil.hpp b/codes/cpp/include/PrintUtil.hpp index 703c7b8..f326f78 100644 --- a/codes/cpp/include/PrintUtil.hpp +++ b/codes/cpp/include/PrintUtil.hpp @@ -210,34 +210,32 @@ class PrintUtil { printTree(root->left, trunk, false); } - /** - * @brief Get the Stack String object - * - * @tparam T - * @param stack - * @return string - */ - template - static string getStackString(stack stack) { - ostringstream s; - if(!stack.empty()){ - s << stack.top(); - stack.pop(); - } - while(!stack.empty()){ - s << ", " << stack.top(); - stack.pop(); - } - return "top->" + s.str() + "]"; - } + /** * @brief Print a stack * * @tparam T - * @param stack + * @param stk */ template - static void printStack(stack &stack) { - cout << getStackString(stack) << '\n'; + static void printStack(stack &stk) { + // Reverse the input stack + stack tmp; + while(!stk.empty()) { + tmp.push(stk.top()); + stk.pop(); + } + // Generate the string to print + ostringstream s; + bool flag = true; + while(!tmp.empty()) { + if (flag) { + s << tmp.top(); + flag = false; + } + else s << ", " << tmp.top(); + tmp.pop(); + } + cout << "[" + s.str() + "]" << '\n'; } };