Swift-棧排序

題目:編寫程序,按升序?qū)_M(jìn)行排序(即最大元素位于棧頂).最多只能使用一個額外的棧存放臨時數(shù)據(jù)。

核心代碼:
<pre><code>` func sort(data:[Int])->[Int] {

    var stack:[Int] = data
    var nextStack:[Int] = []
    
    while stack.count > 0 {
        
        let top:Int = stack.last!
        stack.removeLast() // 移除
        
        while nextStack.count > 0 &&  nextStack.last! > top {
            stack.append(nextStack.last!)
            nextStack.removeLast()
        }
        
        nextStack.append(top)
    }
    
    return nextStack
    
}`</code></pre>

測試代碼:
<pre><code>var stackSort:StackSort = StackSort() var sortData:[Int] = stackSort.sort(data: [8,5,4,3,10,1,7,9,2,6]) print("FlyElephant---排序之后的數(shù)據(jù)---\(sortData)")</code></pre>

FlyElephant.png

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容