LeetCode刷题笔记(简单)---好数对的题目(C语言)

题目如下:
在这里插入图片描述

第一次提交:

int numIdenticalPairs(int* nums, int numsSize){
    int count=0;
    for(int i=0;i<numsSize;i++)
    {
        for(int j=1;j<numsSize;j++)
            if (nums[i]==nums[j]&&(i<j))
                count++;
    }
    return count;
}

结果:
在这里插入图片描述
内存用了这么多,只击败了这么点人,说明还可以再优化,想了一下,第二层循环每次都要判断i<j,可以无形中就多做了一些判断,那么应该可以直接在for循环中规定i<j。于是稍微改善一下

int numIdenticalPairs(int* nums, int numsSize){
    int count = 0;
    for (int i = 0; i < numsSize; i++){
        for(int j = i + 1; j < numsSize; j++){
            if(nums[i] == nums[j])
                count++;
        }
    }
    return count;
}

结果:
在这里插入图片描述
果然是有所提升的。但是这里都是用到了两次循环,那么可不可以只用一次循环呢?翻看了一下大佬们的题解,果然真有大佬只用了一次循环,以下是某大佬的实现:

int numIdenticalPairs(int* nums, int numsSize){
    int hash[101] = {0};
    int ret = 0;

    for(int i = 0; i < numsSize; i++)
    {
        hash[nums[i]]++;
        ret += hash[nums[i]] - 1;
    }

    return ret;
}

作者:barry-9b
链接:https://leetcode-cn.com/problems/number-of-good-pairs/solution/1ci-xun-huan-ha-xi-biao-by-barry-9b/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

在这里插入图片描述
果然减少了内存,但是执行时间增加了。

还有一位大佬也是用的哈希表:

int numIdenticalPairs(int* nums, int numsSize){
    int num = 0;
    int hash[101] = {0};

    // 统计数字出现的次数
    for (int i = 0; i < numsSize; i++) {
        hash[nums[i]]++;
    }
    // 统计好数对的个数
    for (int i = 1; i < 101; i ++) {
        while (hash[i] > 0) {
            num += hash[i] - 1;
            hash[i]--;
        }
    }
    return num;
}

作者:jue-dui-ling-du-3
链接:https://leetcode-cn.com/problems/number-of-good-pairs/solution/ha-xi-biao-by-jue-dui-ling-du-3/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

在这里插入图片描述
他们的思路大概是:数组中一个数的好数对的个数等于 n * (n - 1) / 2, 所以统计每个数字的出现次数即可。
可见,即使是简单的问题,也可以有巧妙的解法,学习了,膜拜大佬。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值