两数之和
题目难度:简单
题目描述:
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。
你可以按任意顺序返回答案。
解决思路:今天偷个小懒,做了非常简单的力扣第一题。用两个for循环就能解决,不过还可以朝时间复杂度小于O(n平方)这个方向改进代码。
我的疑惑:为什么这个方法的返回值在eclipse中是数组的地址,但是在力扣的编译器中却是正常的数组值呢?希望有大神帮帮我。
收获:今天学到了新的返回数组的办法,return new int[]{}。即返回一个新数组,在{}里面可以返回自己指定的数值。
import java.util.Scanner;
public class codeFive{
public int[] twoSum(int[] nums, int target) {
for(int i=0;i<nums.length;i++) {
for(int j=i+1;j<nums.length;j++) {
if(nums[i]+nums[j]==target) {
return new int []{i,j};
}
}
}
return new int[]{};
}
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
String str = sc.next().toString();
int sum = sc.nextInt();
String[] array = str.split(",");
int[] b = new int[array.length];
for(int i=0;i<array.length;i++) {
b[i] = Integer.parseInt(array[i]);
}
codeFive ans = new codeFive();
System.out.println(ans.twoSum(b, sum));
}
}