102 「Map修羅道」 Step04 解答例

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を使った出現回数の集計という定番パターンを学びます。


処理の流れ

  1. 重複を含むリスト(List<String>)を用意する
  2. Map<String, Integer> を使ってカウントを保持する
  3. for ループで1件ずつ処理し、
  • すでに登録されている場合:値を +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での情報集約処理がグッと楽になります。

102 ステップアップ問題 「Map修羅道」