劍指offer 42 和為S的兩個數字

2021-07-31 15:48:55 字數 545 閱讀 2733

題目:輸入乙個遞增排序的陣列和乙個數字s,在陣列中查詢兩個數,使得他們的和正好是s,如果有多對數字的和等於s,輸出兩個數的乘積最小的。 

輸出描述:

對應每個測試案例,輸出兩個數,小的先輸出。

思路:此題關鍵之處在於任意多對兩個數的和相等,乘積最小的兩個數為兩個數之差的絕對值最大,也就是說可以先定義首元素和最後乙個元素,

判斷兩個數之和是否等於給定sum,如果不等,向後遞增或者向前遞減,(注意,該陣列嚴格遞增排序,題目已說明)

class solution 

while (array[i] + array[j] > sum)

j--;

while (array[i] + array[j] < sum)

i++;

}return res;

}};

劍指offer42 和為S的兩個數字 題解

輸入乙個遞增排序的陣列和乙個數字s,在陣列中查詢兩個數,使得他們的和正好是s,如果有多對數字的和等於s,輸出兩個數的乘積最小的。對應每個測試案例,輸出兩個數,小的先輸出。輸入 1,2,4,7,11,15 15返回值 4,11 計算和 s nums i nums j 若 s sum 則指標 j 向左移...

劍指offer42 和為S的連續正數序列

小明很喜歡數學,有一天他在做數學作業時,要求計算出9 16的和,他馬上就寫出了正確答案是100。但是他並不滿足於此,他在想究竟有多少種連續的正數序列的和為100 至少包括兩個數 沒多久,他就得到另一組連續正數和為100的序列 18,19,20,21,22。現在把問題交給你,你能不能也很快的找出所有和...

劍指offer系列(42) 和為S的兩個數字

輸入乙個遞增排序的陣列和乙個數字s,在陣列中查詢兩個數,是的他們的和正好是s,如果有多對數字的和等於s,輸出兩個數的乘積最小的。對應每個測試案例,輸出兩個數,小的先輸出。思路分析採取兩邊夾逼的方法,和前一題類似,兩數和大於s,高字位自減,兩數和小於s,低字位自增 另外吐槽一下,此題第一組數,即兩數差...