题解 | #数组中重复的数字#

数组中重复的数字

https://www.nowcoder.com/practice/6fe361ede7e54db1b84adc81d09d8524

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param numbers int整型一维数组 
 * @param numbersLen int numbers数组长度
 * @return int整型
 */
 //思路:
 //定义一个新数组num,初始化为0,有题目知数组中数的范围和下标范围一致
 //然后将原数组里的值作为新数组num的下标,在原数组中找到与该下标一样的值,则下标指向的值自增
 //最后检查那个下标指向的值大于1,即为重复值
int duplicate(int* numbers, int numbersLen )
{
    // write code here
    //定义一个新数组num,初始化为0,有题目知数组中数的范围和下标范围一致
    int num[numbersLen];
    int i;
    for(i=0; i<numbersLen; i++)
    {
        num[i] = 0;
    }

    //然后将原数组里的值作为新数组num的下标,再原数组中找到与该下标一样的值,则下标指向的值自增
    for(i=0; i<numbersLen; i++)
    {
        num[numbers[i]]++;
    }

     //最后检查那个下标指向的值大于1,即为重复值
    for (i=0; i<numbersLen; i++) 
    {
        if(num[numbers[i]]>1)
        {
            return numbers[i];
        }
    }

    return -1;  //别忘了函数要有返回值
}

全部评论

相关推荐

像好涩一样好学:这公司我也拿过 基本明确周六加班 工资还凑活 另外下次镜头往上点儿
点赞 评论 收藏
分享
10-30 10:16
南京大学 Java
龚至诚:给南大✌️跪了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务