和为S的两个数字

和为S的两个数字_牛客网

https://www.nowcoder.com/practice/390da4f7a00f44bea7c2f3d19491311b?tpId=13&tqId=11195&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目:输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
思路:因为是递增数组,最小的数字加上一个数和为S,那么这两个数的乘积也是最小的;循环遍历外层,里层用二分法。
代码:
public ArrayList<integer> FindNumbersWithSum(int[] array, int sum) {
ArrayList<integer> p = new ArrayList<integer>();
for (int i = 0; i < array.length; i++) {
int low = i + 1;
int hight = array.length;
int mid;
Boolean f = false;
while (low < hight) {
mid = (low + hight) / 2;
if (array[i] + array[mid] == sum) {
p.add(array[i]);
p.add(array[mid]);
f = true;
break;
} else if (array[i] + array[mid] > sum) {
hight = mid - 1;
} else {
low = mid + 1;
}
}
if (f == true) {
break;
}
}
return p;
}</integer></integer></integer>

全部评论

相关推荐

猛踹前端饭碗:你要是大专学历肯定值得去深造,但是本科就还是不推荐去,明显有点牛马的草料味
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
10-12 10:48
已编辑
秋冬春招之苟:邻居家老哥19届双2硕大厂开发offer拿遍了,前几天向他请教秋招,他给我看他当年的简历,0实习实验室项目技术栈跟开发基本不沾边😂,我跟他说这个放在现在中厂简历都过不了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务