牛客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;
}
相关推荐
手握风云-13 分钟前
优选算法的妙思之流:分治——快排专题
数据结构·算法
熬夜苦读学习21 分钟前
Linux进程信号
linux·c++·算法
白白糖24 分钟前
二叉树 递归
python·算法·力扣
jyyyx的算法博客35 分钟前
Leetcode 857 -- 贪心 | 数学
算法·leetcode·贪心·嗜血
ChoSeitaku44 分钟前
NO.64十六届蓝桥杯备战|基础算法-简单贪心|货仓选址|最大子段和|纪念品分组|排座椅|矩阵消除(C++)
算法·矩阵·蓝桥杯
l1n3x1 小时前
编译原理前端-词法分析
算法·编译原理
一只天蝎的晋升之路1 小时前
基础算法之:动态规划
算法·动态规划
KangkangLoveNLP1 小时前
手动实现一个迷你Llama:使用SentencePiece实现自己的tokenizer
人工智能·深度学习·学习·算法·transformer·llama
独好紫罗兰1 小时前
洛谷题单3-P1420 最长连号-python-流程图重构
开发语言·python·算法
柯ran2 小时前
数据结构|排序算法(一)快速排序
数据结构·算法·排序算法