【Leetcode】217. Contains Duplicate

方法一:

思路:

用一个set存储数组中出现过的元素,遍历数组元素,若该元素已存在于set中,则返回true,否则将其加入set。

public class Solution {
    public boolean containsDuplicate(int[] nums) {
        Set<Integer> set = new HashSet<Integer>();
        int len = nums.length;
        for (int i = 0; i < len; i++) {
            if (set.contains(nums[i]))
                return true;
            else
                set.add(nums[i]);
        }
        return false;
    }
}

Runtime:21ms


方法二:

思路:

先将数组排序,然后从第一个开始遍历,如果和后一个值相等,则返回true,终止。

public class Solution {
    public boolean containsDuplicate(int[] nums) {
        Arrays.sort(nums);
        int len = nums.length;
        for (int i = 0; i < len - 1; i++) {
            if (nums[i] == nums[i + 1]) 
                return true;
        }
        return false;
    }
}

时间复杂度为O(nlogn),空间复杂度为O(1)

Runtime:6ms
### LeetCode MySQL Problems and Solutions #### Problem 1: Sales Analysis III Given three tables `Product`, `Sales` with the following structure: | Column Name | Type | |-------------|----------| | product_id | int | | product_name| varchar | | Column Name | Type | |-------------|----------| | seller_id | int | | product_id | int | | buyer_id | int | | sale_date | date | | quantity | int | | price | int | The task is to find products that were only sold in a specific year. ```sql SELECT DISTINCT p.product_id, p.product_name FROM Product AS p JOIN Sales AS s ON p.product_id = s.product_id WHERE YEAR(s.sale_date) = '2018' AND p.product_id NOT IN ( SELECT product_id FROM Sales WHERE YEAR(sale_date) != '2018') ``` This query selects distinct product IDs and names from the `Product` table where sales occurred exclusively in 2018 by filtering out any products sold outside this period[^1]. #### Problem 2: Big Countries A world table contains columns like name, continent, area, population, gdp. The goal is to list all countries larger than 3 million square kilometers or having more than 25 million people. ```sql SELECT name, population, area FROM world WHERE area > 3000000 OR population > 25000000; ``` This SQL statement retrieves country information based on specified size criteria using logical operators[^2]. #### Problem 3: Duplicate Emails With a Person table containing id and email fields, identify duplicate emails within it. ```sql SELECT Email , COUNT(*) as num FROM Person GROUP BY Email HAVING COUNT(*) > 1; ``` By grouping entries according to their email addresses and applying HAVING clause, one can easily spot duplicates[^3]. --related questions-- 1. How does JOIN operation work between two tables? 2. What are common aggregate functions used alongside GROUP BY statements? 3. Can you explain how subqueries function inside main queries? 4. In what scenarios should window functions be preferred over traditional aggregation methods?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值