アルゴリズム?プログラミング。 - 挿入ソート
挿入ソート、insertion sortです。
左端(0番目)をまず整列済として処理は1番目の数字から処理していきます。
選択ソートでは左端の数字を最小の数字にして整列済にします。一度決めたら変更しません。リスト全体から最小の数字を探してから左端に追加します。
最小、最小、・・・
と繋がっていきます。
挿入ソートは左端の数字は整列済として処理しますが、比較する数字はリスト全体ではなく、整列済とした数字の中でさらに比較して並び替えます。
整列済、整列済・・・
リストの対象の数字を整列済の中に入れるときに整列済の中で大小を比較して対象の数字が整列済の中で順番に並ぶような場所に挿入します。
挿入の処理の内容ですが、
まずリストです。これを並び替えします。
nums = [8,4,1,5]
for in文を使って連続で処理するようにします。左はしnums[0]は整列済と考えます。なので処理を開始する数字はnums[1]からなので以下となります。
対象の数字を変数に記憶しておきます。
挿入する前の数字を定義します。比較対象になります。
ここで"i"と"j"ですが、リストの並びからいけば、"i"の方が右側です。
という並びになります。あと、tempはnums[i]で指定される数字です。"i"は順番に変わっていき、それぞれ挿入していきます。
while j >= 0 and nums[j] > tmp:
条件として、"j"は"0"以上で、挿入する数字"tmp"より"num[i]"が大きい時に以下処理します。
nums[j + 1] = nums[j]
j -= 1
同じ数字にすることで挿入する場所を作っています。
"while"なので、条件をチェックしてもし条件に合わなけらば処理を抜けて
nums[j + 1] = tmp
その時の"j"のインデックスのすぐ後ろに挿入します。
流れをprint()関数で出力してもます。
nums = [8,4,1,5]
for i in range(1, len(nums)):
tmp = nums[i]
print(f"{i}回目")
print(tmp)
j = i - 1
while j >= 0 and nums[j] > tmp:
nums[j + 1] = nums[j]
j -= 1
print(nums)
print(tmp)
nums[j + 1] = tmp
print(nums)
#最後
print(nums)
出力は(最初のリストは[8,4,1,5])
一つ前の数字を同じものにして最後に数字をtmpの数字に入れ替える操作の連続で並び替えます。
全体です。
nums = [8,4,1,5]
for i in range(1, len(nums)):
tmp = nums[i]
j = i - 1
while j >= 0 and nums[j] > tmp:
nums[j + 1] = nums[j]
j -= 1
nums[j + 1] = tmp
print(nums)