PowerShellによるバブルソートのサンプルコード

PowerShell
記事内に広告が含まれています。

PowerShellでバブルソートするサンプルコードを作成してみました。

(PowerShellでバブルソートする需要はないと思いますが・・・)

仕様

PowerShellで配列データをバブルソートして、配列データを表示します。

PowerShellは標準でソートの関数が用意されていますが、あえて自力でソート関数を作成します。

ソースコード

バブルソートする部分をbubbleSort関数として別に切り出しました。

テストデータとしてランダムな数字を配列で用意して、ソート前後で表示します。

バブルソート.ps1

# sort function
function bubbleSort($data){
    
    for($i = 0; $i -lt $data.Count - 1; $i++){ # 0 to array.count - 1
        for($j = $i + 1; $j -lt  $data.Count; $j++){  # $i to array.count
            if($data[$i] -gt $data[$j]){

                # swap
                $tmp = $data[$i]
                $data[$i] = $data[$j]
                $data[$j] = $tmp

            }
        }
    }

    return $data
}

$array1 = @(100,0,1,75,3,4,50,2,10,2,99,5,8,7,35,4,8)
# ソート前表示
Write-Host "ソート前"
Write-Host $array1

# バブルソート実行
$array2 = bubbleSort($array1)

# ソート後表示
Write-Host "ソート後"
Write-Host $array2

Read-Host

テスト実行

実行は右クリックメニューの「PowerShellで実行」をクリックします。

実行するとソート前後の配列を表示されます。

そこから数字が小さい順[昇順]であることが確認できました。

参考情報

環境

下記の環境で作成・実行しております。

No.環境バージョン
1OSWindows10
2PowerShell5.1
環境一覧

以上です。