算法题 |
算法刷题专栏 | 面试必备算法 | 面试高频算法
越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
作者简介:硕风和炜,CSDN-Java领域新星创作者,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享
恭喜你发现一枚宝藏博主,赶快收入囊中吧
人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?
算法题 |
给你一个下标从 0 开始长度为 n 的整数数组 nums 和一个整数 target ,请你返回满足 0 <= i < j < n 且 nums[i] + nums[j] < target 的下标对 (i, j) 的数目。
示例 1:
输入:nums = [-1,1,2,3,1], target = 2
输出:3
解释:总共有 3 个下标对满足题目描述:
输入:nums = [-6,2,5,-2,-7,-1,3], target = -2
输出:10
解释:总共有 10 个下标对满足题目描述:
提示:
1 <= nums.length == n <= 50
-50 <= nums[i], target <= 50
class Solution {
public int countPairs(List<Integer> nums, int target) {
int n=nums.size();
int cnt=0;
for(int i=0;i<n;i++){
for(int j=i+1;j<n;j++){
if(nums.get(i)+nums.get(j)<target) cnt++;
}
}
return cnt;
}
}
class Solution {
public int countPairs(List<Integer> nums, int target) {
int n=nums.size();
int cnt=0;
Collections.sort(nums);
for(int i=0;i<n;i++){
int left=i-1,right=n;
while(left+1<right){
int mid=left+right>>1;
if(nums.get(mid)<target-nums.get(i)){
left=mid;
}else{
right=mid;
}
}
if(left!=i-1) cnt+=(left-i);
}
return cnt;
}
}
最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |