馬曉萍
(喀什大學 計算機科學與技術學院,新疆喀什 844000)
冒泡排序是一種典型的、穩(wěn)定排序算法[1],對初次接觸程序語言的學習者來說,排序算法比較抽象,對算法的理解存在較大的障礙。如何讓學生更好直觀的理解排序算法的原理并用程序語言實現(xiàn),是一個值得研究的問題。Unity3D 是一款實時3D 互動內(nèi)容創(chuàng)作和運營平臺,所提供的可視化、實時三維動畫等類型互動內(nèi)容[2],具有強大的交互功能和豐富的三維表現(xiàn)。利用Unity3D 實現(xiàn)冒泡排序算法動態(tài)可視化,是一種有效的算法可視化方式,可促進學習者對冒泡排序算法的理解。
在程序設計語言的排序算法中,冒泡排序是一種平方級的原地排序算法[3]。冒泡排序算法的原理:在待排序的一組數(shù)中,將相鄰的兩個數(shù)值進行比較,若前面的數(shù)值比后面的數(shù)值大就交換兩數(shù),把小數(shù)值放在前面,否則不交換;直至最終完成從小到大的排序。[4]
冒泡排序算法的程序描述(C#語言)如下:
上述代碼中,通過外層for循環(huán),用數(shù)組的長度控制整體程序的運行次數(shù),內(nèi)層for用于與前后兩位數(shù)比較大小,如果存在第一個數(shù)比第二個數(shù)大,則兩個數(shù)利用中間變量temp,實現(xiàn)交換的邏輯。
在Unity 中設計由一個Panel 容器控件,一個Text 文本控件,兩個Button 按鈕控件組成的UI 界面。Text控件文本內(nèi)容為“冒泡排序法三維動態(tài)可視化”,當單擊“隨機生成數(shù)據(jù)”按鈕時,在Panel 容器控件上逐個動態(tài)生成隨機數(shù)據(jù)柱狀圖效果,此案例中隨機生成9 個1~100 的整數(shù),并產(chǎn)生以該整數(shù)作為動態(tài)柱狀圖的高度。當單擊“開始冒泡排序”按鈕時,在Panel 容器控件上,開始進行柱狀圖動態(tài)數(shù)據(jù)的交換,準備比較的兩個柱狀圖變成綠色,等待排序比較,進行完一輪比較后所產(chǎn)生的最大數(shù)柱狀圖變成紅色。
2.2.1 隨機排序數(shù)據(jù)類的設計
(1)設計一個RandomData 類用于生成隨機數(shù)。如圖1所示。
圖1 RandomData類圖
部分代碼如下:
(2)利用協(xié)程機制動態(tài)生成柱狀圖的接口設計.
該接口中,go.GetComponent<Transform>().position 語句表示動態(tài)生成柱狀圖的位置,t.Get-Component<Transform>().position 語句表示隨機產(chǎn)生數(shù)據(jù)的文本顯示在當前柱狀圖y 軸上方v.y+0.5位置。通過測試,Unity中無法直接調用接口,為了實現(xiàn)接口InitBarGraph()和接口Sort()的功能,本案例中編寫了兩個方法,使用StartCall()方法分別調用接口。調用接口InitBarGraph()參考代碼如下:
動態(tài)生成隨機柱狀圖效果圖如下圖2所示。
圖2 隨機柱狀圖
2.2.2 冒泡排序類的設計
(1)冒泡排序及柱狀圖顏色變化的接口設計。
該接口主要實現(xiàn)設置準備比較的兩個柱狀圖顏色、待排數(shù)的柱狀圖顏色,最大數(shù)的柱狀圖顏色,以及進行柱狀圖動態(tài)數(shù)據(jù)的交換的冒泡排序功能,程序流程圖如圖3所示。
圖3 可視化冒泡排序流程圖
部分代碼如下:
(2)柱狀圖的位置和高度的方法。
該方法用以實現(xiàn)柱狀圖、柱狀圖上隨機數(shù)數(shù)字的位置和高度的設置,使得數(shù)據(jù)始終顯示在柱狀圖正上方的功能。
部分代碼如下:
(3)實現(xiàn)第一輪冒泡排序的效果圖如圖4 所示。
圖4 第一輪冒泡排序效果圖
本文利用Unity3D 平臺,以“C#程序設計”課程中的冒泡排序為案例,利用協(xié)程動態(tài)生成隨機數(shù)據(jù)柱狀圖,并以三維動態(tài)可視化實現(xiàn)C#腳本語言的冒泡排序算法,直觀動態(tài)地展示了冒泡排序算法的基本思想和排序過程。實驗證明,動態(tài)可視化的課程設計,既通過Unity3D 創(chuàng)建三維動態(tài)互動內(nèi)容提高了學習者的學習興趣,又加深了學習者對冒泡排序算法原理的理解性,達到了良好的教學效果。