牛客NC30 缺失的第一个正整数【simple map Java,Go,PHP】

题目

题目链接:

https://www.nowcoder.com/practice/50ec6a5b0e4e45348544348278cdcee5

核心

复制代码
Map

参考答案Java

java 复制代码
import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param nums int整型一维数组
     * @return int整型
     */
    public int minNumberDisappeared (int[] nums) {
        Map<Integer, Integer> map = new HashMap<>();
        for (int num : nums) {
            map.put(num, num);
        }

        int i = 1;
        while (map.containsKey(i)) {
            i++;
        }
        return i;
    }
}

参考答案Go

go 复制代码
package main

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param nums int整型一维数组
 * @return int整型
 */
func minNumberDisappeared(nums []int) int {
	m := map[int]int{}
	for k, v := range nums {
		m[v] = k
	}

	i := 1

	for true {
		_, ok := m[i]
		if !ok {
			break
		}

		i++
	}
	return i
}

参考答案PHP

php 复制代码
<?php


/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param nums int整型一维数组 
 * @return int整型
 */
function minNumberDisappeared( $nums )
{
    $map = array();
    foreach ($nums as  $k=>$v){
        $map[$v] = $k;
    }
    
    $i=1;
    while (isset($map[$i])){
        $i++;
    }
    return $i;
}
相关推荐
m0_736919102 分钟前
C++中的享元模式变体
开发语言·c++·算法
罗湖老棍子8 分钟前
【 例 1】石子合并(信息学奥赛一本通- P1569)
数据结构·算法·区间dp·区间动态规划·分割合并
wangluoqi25 分钟前
26.2.4练习总结
算法
流㶡30 分钟前
逻辑回归实战:从原理到不平衡数据优化(含欠拟合/过拟合诊断与召回率提升)
算法·机器学习·逻辑回归
Tisfy37 分钟前
LeetCode 3637.三段式数组 I:一次遍历(三种实现)
算法·leetcode·题解·模拟·数组·遍历·moines
遨游xyz44 分钟前
数据结构-哈希表
算法·哈希算法
dyyx1111 小时前
C++中的过滤器模式
开发语言·c++·算法
lrh1228001 小时前
详解决策树算法:分类任务核心原理、形成流程与剪枝优化
算法·决策树·机器学习
期末考复习中,蓝桥杯都没时间学了1 小时前
力扣刷题15
算法·leetcode·职场和发展
2301_817497332 小时前
C++中的装饰器模式高级应用
开发语言·c++·算法