摘要:難度就是說給一個整數(shù)數(shù)組如給一個目標數(shù)字如從數(shù)組中找出相加為這個目標數(shù)字的兩個數(shù)的下標就返回的下標只需要給出滿足條件的一對數(shù)字即可這個題想起來比較直接此處給出兩種解法這之后的題目中還有多個數(shù)字相加的相對較難的題目第一種將數(shù)組排序以兩個游標
Two Sum
Given an array of integers, return indices of the two numbers such that they add up to a specific target.
You may assume that each input would have exactly one solution.
Example:
Given nums = [2, 7, 11, 15], target = 9,Because nums[0] + nums[1] = 2 + 7 = 9, return [0, 1].
UPDATE (2016/2/13):
The return format had been changed to zero-based indices. Please read the above updated description carefully.
難度: Easy.
就是說, 給一個整數(shù)數(shù)組(如[2, 7, 11, 15]), 給一個目標數(shù)字(如9), 從數(shù)組中找出相加為這個目標數(shù)字的兩個數(shù)的下標. 2+7=9, 就返回2,7的下標[0,1]. 只需要給出滿足條件的一對數(shù)字即可.
這個題想起來比較直接, 此處給出兩種解法, 這之后的題目中, 還有多個數(shù)字相加的相對較難的題目.
第一種:
將數(shù)組排序, 以兩個游標從兩頭向中間逼近
如果和偏大, 就把右游標向左挪動
如果和偏小, 就把左游標向右挪動
最終返回正確的下標. 此算法時間復雜度是 O(nlogn).
public class Solution { public int[] twoSum(int[] nums, int target) { class Pair { int idx; int val; } Pair[] pnums = new Pair[nums.length]; for (int i = 0; i < nums.length; i++) { pnums[i] = new Pair(); pnums[i].idx = i; pnums[i].val = nums[i]; } Arrays.sort(pnums, new Comparator() { @Override public int compare(Pair o1, Pair o2) { if (o1.val > o2.val) { return 1; } else if (o1.val < o2.val) { return -1; } else { return 0; } } }); int lp = 0; int rp = nums.length - 1; while (true) { int sum = pnums[lp].val + pnums[rp].val; if (sum == target) { break; } else if (sum > target) { rp--; } else { lp++; } } if (pnums[lp].idx < pnums[rp].idx) { return new int[] { pnums[lp].idx, pnums[rp].idx }; } else { return new int[] { pnums[rp].idx, pnums[lp].idx }; } } public static void main(String[] args) { int[] a1 = { 3, 2, 4 }; Solution s = new Solution(); int[] ret = s.twoSum(a1, 6); System.out.println("" + ret[0] + " " + ret[1]); } }
第二種:
使用一個map, 記錄值->下標的映射關系(重復的值其實覆蓋了沒關系).
循環(huán)看每個值, 對于值a, 從map中查找(target-a), 如果存在, 則輸出這兩個數(shù)值的下標即可.
由于使用HashMap, 算法的時間復雜度是O(n)
public class Solution2 { public int[] twoSum(int[] nums, int target) { Mapnmap = new HashMap (); for (int i = 0; i < nums.length; i++) { nmap.put(nums[i], i); } int i = 0; int j = 0; for (; i < nums.length; i++) { if (nmap.containsKey(target - nums[i])) { j = nmap.get(target - nums[i]); if (i != j) { break; } } } if (i < j) { return new int[] { i, j }; } else { return new int[] { j, i }; } } public static void main(String[] args) { int[] a1 = { 3, 2, 4 }; Solution2 s = new Solution2(); int[] ret = s.twoSum(a1, 6); System.out.println("" + ret[0] + " " + ret[1]); } }
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/66378.html
摘要:返回這兩個元素的位置。每個輸入都有且僅有一組滿足條件的元素。想法如果使用蠻力法可以簡單的解決這個問題。但是需要兩層循環(huán),效率低。用來存儲,每一個元素和目標元素的差值和這個元素的位置。因為里的對象也是鍵值對。 題目詳情 Given an array of integers, return indices of the two numbers such that they add up t...
摘要:返回這兩個元素的位置。每個輸入都有且僅有一組滿足條件的元素。想法如果使用蠻力法可以簡單的解決這個問題。但是需要兩層循環(huán),效率低。用來存儲,每一個元素和目標元素的差值和這個元素的位置。因為里的對象也是鍵值對。 題目詳情 Given an array of integers, return indices of the two numbers such that they add up t...
摘要:如果是奇數(shù)的話,那一定是不滿足條件的,可以直接返回。如果是偶數(shù),將除獲得我們要求的一個子數(shù)組元素的和。如何暫存我們計算的中間結果呢聲明一個長度為的布爾值數(shù)組。每個元素的布爾值代表著,數(shù)組中是否存在滿足加和為的元素序列。 題目詳情 Given a non-empty array containing only positive integers, find if the array ca...
摘要:我們的目的是求出兩個數(shù)字的加和,并以同樣的形式返回。假設每個都不會存在在首位的,除非數(shù)字本身就是想法這道題主要要求還是熟悉的操作。這道題由于數(shù)字反序,所以實際上從首位開始相加正好符合我們筆算的時候的順序。 題目詳情 You are given two non-empty linked lists representing two non-negative integers. The d...
摘要:如果沒有,就到里面復雜度分析就是,因為只掃了一遍數(shù)組。復雜度分析當然就是最壞情況了,也是標準的雙指針復雜度。復雜度分析這種題應該不太需要分析復雜度吧,能實現(xiàn)就行。復雜度分析還是最后再說兩句所以可以看出,很多題目思路一致,換湯不換藥。 Two Sum 友情提示:篇幅較長,找題目的話,右邊有目錄,幸好我會MarkDown語法。改成了系列模式,因為類似的題不少,本質(zhì)上都是換殼,所以在同一篇文...
閱讀 2919·2021-11-17 09:33
閱讀 1639·2021-10-12 10:13
閱讀 2462·2021-09-22 15:48
閱讀 2338·2019-08-29 17:19
閱讀 2596·2019-08-26 11:50
閱讀 1572·2019-08-26 10:37
閱讀 1738·2019-08-23 16:54
閱讀 2925·2019-08-23 14:14