简单
给你一个整数数组 nums 。
如果一组数字 (i,j) 满足 nums[i] == nums[j] 且 i < j ,就可以认为这是一组 好数对 。
返回好数对的数目。
示例 1:
输入:nums = [1,2,3,1,1,3] 输出:4 解释:有 4 组好数对,分别是 (0,3), (0,4), (3,4), (2,5) ,下标从 0 开始
示例 2:
输入:nums = [1,1,1,1] 输出:6 解释:数组中的每组数字都是好数对
示例 3:
输入:nums = [1,2,3] 输出:0
提示:
-
1 <= nums.length <= 100 1 <= nums[i] <= 100
代码:
class Solution {
public int numIdenticalPairs(int[] nums) {
}
}
答案:
//暴力破解
class Solution {
public int numIdenticalPairs(int[] nums) {
int res = 0;
for (int i = 0; i < nums.length; i++) {
for (int j = i + 1; j < nums.length; j++) {
if (nums[i] == nums[j]) {
res=res+1;
}
}
}
return res;
}
}
//大佬题解
class Solution {
public int numIdenticalPairs(int[] nums) {
int res = 0; // 记录数字对的总数
int[] counter = new int[101]; // 记录每个数字出现的次数
for (int n : nums) {
res += counter[n]; //遍历数组nums中的每个数字n
counter[n]++; //res累加n在数组中对应位置的值(即n出现的次数)
//然后n在counter中的计数加1
//如数字出现1次为0,出现2次为1,出现3次为1+2=3
//出现4次为1+2+3=6,出现5次为1+2+3+4=10
}
return res;
}
}