leetcode 初级之数组篇 04

存在重复

给定一个整数数组,判断是否存在重复元素。

如果任何值在数组中出现至少两次,函数返回 true。如果数组中每个元素都不相同,则返回 false。

示例 1:

输入: [1,2,3,1]
输出: true
示例 2:

输入: [1,2,3,4]
输出: false
示例 3:

输入: [1,1,1,3,3,4,3,2,4,2]
输出: true
// 执行用时 1752ms  击败35%
// 经查阅,先使用排序函数,对数组进行排序,效率会高很多
bool containsDuplicate(int* nums, int numsSize) {
    for (int i = 0; i < numsSize -1 ; i++) {
        for (int j = i + 1; j < numsSize; j++) {
            if (nums[i] == nums[j]) {
                return true;
            }
        }
    }
    return false;
}
int main(int argc, const char * argv[]) {
    @autoreleasepool {
        int arr[] = {1,1,1,3,3,4,3,2,4,2};
        int arr1[] = {1,2,3,4};
        
       bool a = containsDuplicate(arr, 10);
       bool b = containsDuplicate(arr1, 4);
        printf("%d %d\n",a,b);
        
    }
    return 0;
}

你可能感兴趣的:(leetcode 初级之数组篇 04)