日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

c++两个数组对比去掉重复的元素_LeetCode 题解 | 167.两数之和 II 输入有序数组...

發布時間:2024/9/27 c/c++ 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c++两个数组对比去掉重复的元素_LeetCode 题解 | 167.两数之和 II 输入有序数组... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方藍字設為星標

下面開始今天的學習~

力扣?167.兩數之和 II - 輸入有序數組(點擊文末閱讀原文查看題目)題目描述

給定一個已按照?升序排列?的有序數組,找到兩個數使得它們相加之和等于目標數。

函數應該返回這兩個下標值 index1 和 index2,其中 index1 必須小于 index2。

說明:

  • 返回的下標值(index1 和 index2)不是從零開始的。
  • 你可以假設每個輸入只對應唯一的答案,而且你不可以重復使用相同的元素。

示例:

輸入: numbers = [2, 7, 11, 15], target = 9輸出: [1,2]解釋: 2 與 7 之和等于目標數 9 。因此 index1 = 1, index2 = 2 。解決方案

方法 1:雙指針

算法我們可以使用 力扣 1.兩數之和的解法在 O(n^2)?時間 O(1)?空間暴力解決,也可以用哈希表在 O(n)?時間和 O(n)?空間內解決。然而,這兩種方法都沒有用到輸入數組已經排序的性質,我們可以做得更好。我們使用兩個指針,初始分別位于第一個元素和最后一個元素位置,比較這兩個元素之和與目標值的大小。如果和等于目標值,我們發現了這個唯一解。如果比目標值小,我們將較小元素指針增加一。如果比目標值大,我們將較大指針減小一。移動指針后重復上述比較知道找到答案。

假設?[...,a,b,c,...,d,e,f,...]?是已經升序排列的輸入數組,并且元素 b,e 是唯一解。因為我們從左到右移動較小指針,從右到左移動較大指針,總有某個時刻存在一個指針移動到 b 或 e 的位置。不妨假設小指針縣移動到了元素 b,這是兩個元素的和一定比目標值大,根據我們的算法,我們會向左移動較大指針直至獲得結果。

C++ 代碼實現

class Solution {public: vector<int> twoSum(vector<int>& numbers, int target) { int low = 0, high = numbers.size() - 1; while (low < high) { int sum = numbers[low] + numbers[high]; if (sum == target) return {low + 1, high + 1}; else if (sum < target) ++low; else --high; } return {-1, -1}; }};是否需要考慮 numbers[low] + numbers[high]?溢出呢?答案是不需要。因為即使兩個元素之和溢出了,因為只存在唯一解,所以一定會先訪問到答案。復雜度分析

時間復雜度:O(n)。每個元素最多被訪問一次,共有 n 個元素。

空間復雜度:O(1)。只是用了兩個指針。

本文作者:力扣

編輯&版式:霍霍

聲明:本文歸“力扣”版權所有,如需轉載請聯系。

點個在看,少個?bug?

總結

以上是生活随笔為你收集整理的c++两个数组对比去掉重复的元素_LeetCode 题解 | 167.两数之和 II 输入有序数组...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。