如何在MapJava中检查元素重复

如何在MapJava中检查元素重复,java,collections,java-console,Java,Collections,Java Console,我有一个函数,它允许在地图中输入键和值 这是我的密码 import java.util.HashMap; import java.util.Map; import java.util.Scanner; public class MapDemo { public static void main(String[] args) { Scanner input = new Scanner(System.in); Map<String, Integer&g

我有一个函数,它允许在地图中输入键和值

这是我的密码

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class MapDemo {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        Map<String, Integer> map = new HashMap<>();
        System.out.println("Elemment number: ");
        String sNum = input.nextLine();
        int iNum = Integer.parseInt(sNum);
        for (int i = 0; i < iNum; i++) {
            System.out.println("Key: ");
            String sKey = input.nextLine();
            System.out.println("Value: ");
            String sValue = input.nextLine();
            int iValue = Integer.parseInt(sValue);
            map.put(sKey, iValue);
        }
    }
}

我不知道接下来如何检查元素,我将输入它。它与前面的元素相同,如果相同,我将再次输入。

在实现集合接口的每个数据结构中都有一个Collection.contains方法

添加while循环:

  public static void main(String[] args) {
    Scanner input = new Scanner(System.in);
    Map<String, Integer> map = new HashMap<>();
    System.out.println("Elemment number: ");
    String sNum = input.nextLine();
    int iNum = Integer.parseInt(sNum);
    for (int i = 0; i < iNum; i++) {
        String sKey ;
        do {
            System.out.println("Key: ");
            sKey = input.nextLine();
        } while (map.containsKey(sKey));

        System.out.println("Value: ");
        String sValue = input.nextLine();
        int iValue = Integer.parseInt(sValue);
        map.put(sKey, iValue);
    }
 }

map.containsKeysKey;但这张地图实际上不是一个收藏。抱歉。您可以执行Map.keySet,然后运行Collection.contains检查!!!!!非常感谢,它成功了