居左


私信TA

用户名:JZ50

访问量:71255

签 名:

楼下你的分数已经再次被超越!!快刷!!

等  级
排  名 32
经  验 13649
参赛次数 2
文章发表 109
年  龄 0
在职情况 学生
学  校 99
专  业

  自我简介:

解题思路:

    1. 重号:使用Map存储ID,判断重复key,即可得到重复ID

    2. 断号:先得到所有ID序列的最小值和最大值,循环判断不存在于Map中的ID,即可得到断号



注意事项:





参考代码:

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

public class C1458 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while (sc.hasNext()) {
			int m = 0, n = 0;
			int N = sc.nextInt();
			sc.nextLine();
			Map<Integer, Integer> map = new HashMap<Integer, Integer>();
			int min = Integer.MAX_VALUE, max = 0, num;
			for(int i = 0; i < N; i++){
				String[] strs = sc.nextLine().split("[ ]+");
				for(String str : strs){
					num = Integer.valueOf(str);
					if(map.containsKey(num)) //重号ID
						n = num;
					else
						map.put(num, num);
						
					if(num < min)
						min = num;
					if(num > max)
						max = num;
				}
			}
			
			for(int i = min; i <= max; i++){
				if(!map.containsKey(i)){//断号
					m = i;
					break;
				}
			}
			System.out.printf("%d %d", m, n);
		}
		sc.close();
	}
	
}


 

0.0分

4 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区