两数之和
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 的那 两个 整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum
核心代码
//定义一个i
int i=0;
/*这里我用了while循环中嵌套for循环,也可用双重for循环,内层for循环先将nums[i]与数组中其他元素进行运算,
如果nums[i]+nums[j]==target,则循环结束,输出结果,如果当就=>nums.length是,if语句中的判断条件为false,
则跳出for循环,进行i++while循环,i++后,再次进入for循环,直至得出结果
*/
while(i<nums.length) {
//定义的j代表数组中元素nums[i]后边的元素的下标
for(int j=i+1;j<nums.length;j++) {
if(nums[i]+nums[j]==target) {
System.out.println("["+i+","+j+"]");
break;
}
}
i++;
}
完整代码
import java.util.Scanner;
public class 两数之和 {
public static void main(String[] args) {
//键盘录入数组
Scanner sc=new Scanner(System.in);
System.out.println("输入数据:");
String str = sc.next().toString();
String[] arr = str.split(",");
int[] nums = new int[arr.length];
System.out.println("输入的数组:");
for(int j = 0; j<nums.length;j++) {
nums[j] = Integer.parseInt(arr[j]);
System.out.print(nums[j]+" ");
}
//键盘录入数据
System.out.println("输入target:");
int target=sc.nextInt();
//核心代码
int i=0;
while(i<nums.length) {
for(int j=i+1;j<nums.length;j++) {
if(nums[i]+nums[j]==target) {
System.out.println("["+i+","+j+"]");
}
}
i++;
}
}
}