牛客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;
}
相关推荐
重生之后端学习1 天前
19. 删除链表的倒数第 N 个结点
java·数据结构·算法·leetcode·职场和发展
aini_lovee1 天前
严格耦合波(RCWA)方法计算麦克斯韦方程数值解的MATLAB实现
数据结构·算法·matlab
安特尼1 天前
推荐算法手撕集合(持续更新)
人工智能·算法·机器学习·推荐算法
鹿角片ljp1 天前
力扣14.最长公共前缀-纵向扫描法
java·算法·leetcode
Remember_9931 天前
【数据结构】深入理解优先级队列与堆:从原理到应用
java·数据结构·算法·spring·leetcode·maven·哈希算法
偷星星的贼111 天前
C++中的状态机实现
开发语言·c++·算法
程序员敲代码吗1 天前
C++中的组合模式实战
开发语言·c++·算法
52Hz1181 天前
二叉树理论、力扣94.二叉树的中序遍历、104.二叉树的最大深度、226.反转二叉树、101.对称二叉树
python·算法·leetcode
Shirley~~1 天前
leetcode移除元素
javascript·数据结构·算法
普贤莲花1 天前
新生2026年1月20日---星期二(大寒)
程序人生·算法·leetcode