Python - 配列の並べ替え
こんにちは、Pythonプログラマー志望の皆さん!今日は、Pythonでの配列の並べ替えについて素晴らしい世界に飛び込んでいきます。プログラミング初心者であっても心配しないでください。例と説明をたくさん用意して、各ステップをガイドします。このチュートリアルの終わりまでに、プロのように配列を並べ替えることができるようになります!
Pythonでの配列とは?
並べ替えに入る前に、Pythonでの配列について簡単に説明します。Pythonでは、通常、リストを配列として使用します。リストは、異なる型のアイテムのコレクションです。例えば:
fruits = ["apple", "banana", "cherry", "date"]
numbers = [42, 8, 15, 16, 23]
ソートアルゴリズムを使用して配列を並べ替える
まず、初心者には理解しやすい基本的なソートアルゴリズム「バブルソート」から始めます。最も効率的ではありませんが、簡単です。
バブルソート
以下は、バブルソートの簡単な実装です:
def bubble_sort(arr):
n = len(arr)
for i in range(n):
for j in range(0, n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
return arr
# 使用例
numbers = [64, 34, 25, 12, 22, 11, 90]
sorted_numbers = bubble_sort(numbers)
print("並べ替えられた配列:", sorted_numbers)
これを分解してみましょう:
-
bubble_sort
という関数を定義し、配列(リスト)を入力とします。 - 配列の長さを取得し、
n
に格納します。 - 2重のループを使用して隣接する要素を比較します。
- 要素が次の要素より大きい場合、交換します。
- これを繰り返して、全ての配列が並べ替えられるまで続けます。
このコードを実行すると、以下のようになります:
並べ替えられた配列: [11, 12, 22, 25, 34, 64, 90]
楽しい事実:バブルソートは、小さな要素が各反復でリストのトップに「泡」のように浮かぶので、その名前がついています!
listのsort()メソッドを使用して配列を並べ替える
Pythonのリストには、並べ替えを容易にするビルトインのsort()
メソッドがあります。どのように動作するかを見てみましょう:
# 数値の並べ替え
numbers = [64, 34, 25, 12, 22, 11, 90]
numbers.sort()
print("並べ替えられた数値:", numbers)
# 文字列の並べ替え
fruits = ["banana", "cherry", "apple", "date"]
fruits.sort()
print("並べ替えられた果物:", fruits)
出力:
並べ替えられた数値: [11, 12, 22, 25, 34, 64, 90]
並べ替えられた果物: ['apple', 'banana', 'cherry', 'date']
sort()
メソッドは元のリストを変更します。これは、部屋を片付けるのに似ています。すべてが整然となりますが、それでもあなたの部屋です!
降順で並べ替える
reverse=True
パラメータを追加することで、降順で並べ替えることもできます:
numbers = [64, 34, 25, 12, 22, 11, 90]
numbers.sort(reverse=True)
print("降順で並べ替えられた数値:", numbers)
出力:
降順で並べ替えられた数値: [90, 64, 34, 25, 22, 12, 11]
sorted()関数を使用して配列を並べ替える
sorted()
関数も、Pythonでの並べ替えに使用される強力なツールです。sort()
とは異なり、元のリストを変更せず、新しい並べ替えられたリストを返します。
# 数値の並べ替え
numbers = [64, 34, 25, 12, 22, 11, 90]
sorted_numbers = sorted(numbers)
print("元の数値:", numbers)
print("並べ替えられた数値:", sorted_numbers)
# 文字列の並べ替え
fruits = ["banana", "cherry", "apple", "date"]
sorted_fruits = sorted(fruits)
print("元の果物:", fruits)
print("並べ替えられた果物:", sorted_fruits)
出力:
元の数値: [64, 34, 25, 12, 22, 11, 90]
並べ替えられた数値: [11, 12, 22, 25, 34, 64, 90]
元の果物: ['banana', 'cherry', 'apple', 'date']
並べ替えられた果物: ['apple', 'banana', 'cherry', 'date']
sorted()
は、リストのコピーを作成し、そのコピーを並べ替えることを考えてください。元のリストは触れません。これは、散らかった部屋の写真を撮り、写真を整然としている間、実際の部屋はそのままになります!
カスタムキーを使用して並べ替える
sorted()
の最もクールな機能の一つは、カスタム並べ替えキーを使用することです。例えば、単語のリストを長さで並べ替える場合:
words = ["python", "is", "awesome", "and", "fun"]
sorted_words = sorted(words, key=len)
print("長さで並べ替えられたもの:", sorted_words)
出力:
長さで並べ替えられたもの: ['is', 'and', 'fun', 'python', 'awesome']
ここでは、len
をキー関数として使用しました。Pythonはこの関数を各アイテムに適用し、その結果に基づいて並べ替えます。
ソートメソッドの比較
学んだソートメソッドを便利な表にまとめましょう:
メソッド | 元のリストを変更 | 新しいリストを返す | カスタムキーを使用可能 |
---|---|---|---|
バブルソート | はい | いいえ | いいえ |
list.sort() |
はい | いいえ | はい |
sorted() |
いいえ | はい | はい |
結論
おめでとうございます!Pythonで配列を並べ替えるいくつかの方法を学びました。独自のソートアルゴリズムを実装することから、Pythonのビルトインメソッドを使用することまで、データを整理するためのツールをお持ちでしょう。
覚えておきましょう、並べ替えは本を棚に並べるように、たくさんの方法があり、最良の方法は何を達成しようとしているかに依存します。異なるタイプのデータとソートメソッドを実践して、Pythonのソートマスターになりましょう!
幸せなコーディングを、そして常に完璧に並べ替えられた配列があるように! ??
Credits: Image by storyset