我是靠谱客的博主 朴素夕阳,最近开发中收集的这篇文章主要介绍Java-练习1-两数之和-给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那两个整数,并返回它们的数组下标。两数之和,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

两数之和

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那两个整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。
解题思路:
定义变量i和j控制指针,定义变量num接受每次便利算出的结果,利用while循环的方式进行遍历,如果num等于target结束循环,时间复杂度Ologn(时间复杂度是网上找的while的时间复杂度,不知道对不对,如果不对请在评论区帮我指正,在此感谢!)。
方法如下:(如有更好的方法,打在评论区,在此感谢!)

//定义方法,将索引放入SortedSet中自行排序
static SortedSet<Integer> index(int[] nums, int target){
int num = 0;
int i = 0;
int j = 1;
SortedSet<Integer> indexSet = new TreeSet<>();
while (!(num == target)){
if (j == nums.length -1){
i++;
j = 0;
}
num = nums[i] + nums[j];
if (num == target){
indexSet.add(i);
indexSet.add(j);
}
j++;
}
return indexSet;
}

测试代码:


int[] nums = {2,7,11,15};
int target = 9;
System.out.println(index(nums,target));

结果如下:
测试结果
博主的碎碎念:
想把平时的练习都分享分享,在这里交流学习,提高自己。
在下新人一枚,请各位不吝赐教,再次感谢!

最后

以上就是朴素夕阳为你收集整理的Java-练习1-两数之和-给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那两个整数,并返回它们的数组下标。两数之和的全部内容,希望文章能够帮你解决Java-练习1-两数之和-给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那两个整数,并返回它们的数组下标。两数之和所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部