最新回答 / 慕田峪2224101
template<typename T>?int& MyStack<T>::operator[](int i) {? ? ?return m_pBuffer[i];}我是這么實現的,但是好像行不通報錯:?no match for 'operator[]' (operand types are 'char [17]' and 'MyStack<int>')|但是我感覺這樣可以重載呀
2018-03-01
最新回答 / 慕尼黑8374427
怎么可能啊,m_iTop最多就是n,push()方法一開始不是有判斷是否為full么,你push第n+1個元素的時候就直接return false,根本執行不到m_iTop++
2018-02-03
最新回答 / 慕標6516834
elem只是作為一個中間值,做一個跳板,在m_iTop下標減一,指向出棧,如果寫成m_pBuffer[m_iTop] = elem,因為傳遞的是引用,那么你的m_pBuffer[m_iTop]的值就被賦值為你主函數傳遞的值。個人見解,理解錯了,勿噴。
2017-07-28
最新回答 / BingBing_Elf
首先,我覺得你可能沒明白棧頂元素的位置,它的位置一直是在一個空位置,這樣才可以有位置來存儲新的進棧元素,這也是老師說為什么m_iTop這個角標和元素個數相等的原因,也就是說,當你元素為5個時,存儲的角標為0-4,但是你的m_iTop在5的位置。所以,在空棧的情況下,是不是首位置就應該是空的,即它的角標為0,當一個元素入棧后,就可以插入到角標為m_iTop的位置了,插入后一定要進行m_iTop++,讓指針指向下一個位置,以便下一個元素的入棧。希望可以幫到你(????)
2017-07-07
最贊回答 / 我是一只小蝸牛
因為C++ 默認的拷貝構造函數是淺拷貝,咋們案例是值這種東西,所以可以直接賦值;但是如果涉及到指針,那么用淺拷貝容易造成內存泄漏,因為你的地址是一樣的,釋放兩次會出現內存泄漏,這時候你就要自己實現拷貝構造函數了,而不能使用默認的拷貝構造函數
2017-06-03