MapUtil.java
import java.util.*;
public class MapUtil {
public static void countOrders() {
// 注文された商品リスト(重複あり)
List<String> orders = Arrays.asList(
"apple", "banana", "apple", "orange", "banana", "apple"
);
// 商品ごとのカウントを保持するMapを作成
Map<String, Integer> countMap = new HashMap<>();
// 注文リストを1件ずつ処理
for (String item : orders) {
// すでにその商品がMapにあれば、値を1増やす
if (countMap.containsKey(item)) {
int currentCount = countMap.get(item); // 現在のカウントを取得
countMap.put(item, currentCount + 1); // 1増やして再登録
} else {
// 初めて出現した商品 → 1を登録
countMap.put(item, 1);
}
}
// 結果を出力(出現回数を表示)
for (Map.Entry<String, Integer> entry : countMap.entrySet()) {
System.out.println(entry.getKey() + " → " + entry.getValue());
}
}
}
解説:Mapを使って「数える」
このステップでは、Mapを使った出現回数の集計という定番パターンを学びます。
処理の流れ
- 重複を含むリスト(
List<String>
)を用意する Map<String, Integer>
を使ってカウントを保持するfor
ループで1件ずつ処理し、
- すでに登録されている場合:値を +1
- はじめてのキー:値を 1 で初期化
- 最終的に、商品ごとの出現回数を表示する
containsKey()
を使う理由
カウント処理では、まずそのキーがすでにMapにあるかを確認しないといけません。
ない場合は null
を返すので、いきなり get()
して +1
しようとすると NullPointerException
が出る可能性があります。
getOrDefault()
を使った別解(参考)
int count = countMap.getOrDefault(item, 0);
countMap.put(item, count + 1);
getOrDefault(key, defaultValue)
は、キーが存在しない場合にdefaultValue
を返してくれる便利メソッドです。- Java8以降で利用可能(初学者には最初は明示的な
containsKey()
の方がわかりやすい)
実行結果の例(順不同):
apple → 3
banana → 2
orange → 1
まとめ:このステップで学ぶべきこと
- 値の型が
Integer
になっても、Map
の基本操作は同じ - 集計処理の定石:「存在確認 → 加算 or 初期化」
- 出現回数カウントは実務でもよく使われる重要パターン
このステップをきっちり理解できれば、Mapでの情報集約処理がグッと楽になります。