java two sum,TwoSum.java

import java.util.Arrays;

import java.util.Comparator;

/**

* Given an array of integers, find two numbers such that they add up to a

* specific target number.

*

* The function twoSum should return indices of the two numbers such that they

* add up to the target, where index1 must be less than index2. Please note that

* your returned answers (both index1 and index2) are not zero-based.

*

* You may assume that each input would have exactly one solution.

*

* Input: numbers={2, 7, 11, 15}, target=9 Output: index1=1, index2=2

*/

public class TwoSum {

public class Num {

private int value;

private int index;

public Num(int value, int index) {

super();

this.value = value;

this.index = index;

}

public int getIndex() {

return index;

}

public void setIndex(int index) {

this.index = index;

}

public int getValue() {

return value;

}

public void setValue(int value) {

this.value = value;

}

}

public int[] twoSum(int[] numbers, int target) {

Num[] newArray = new Num[numbers.length];

for (int i = 0; i < numbers.length; i++) {

newArray[i] = new Num(numbers[i], i);

}

Arrays.sort(newArray, new Comparator() {

public int compare(Num n1, Num n2) {

if (n1.getValue() == n2.getValue())

return 0;

if (n1.getValue() > n2.getValue())

return 1;

return -1;

}

});

int[] result = new int[2];

int i = 0, j = numbers.length - 1;

while (i < j) {

int tmp = newArray[i].getValue() + newArray[j].getValue();

if (tmp == target) {

result[0] = Math.min(newArray[i].getIndex() + 1,

newArray[j].getIndex() + 1);

result[1] = Math.max(newArray[i].getIndex() + 1,

newArray[j].getIndex() + 1);

break;

} else if (tmp > target) {

j--;

} else {

i++;

}

}

return result;

}

}

一键复制

编辑

Web IDE

原始数据

按行查看

历史

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值