题目如下:
第一次提交:
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, 所以统计每个数字的出现次数即可。
可见,即使是简单的问题,也可以有巧妙的解法,学习了,膜拜大佬。