Cool说丨力扣153、454

简介: 153. 寻找旋转排序数组中的最小值454. 四数相加 II

153. 寻找旋转排序数组中的最小值

假设按照升序排序的数组在预先未知的某个点上进行了旋转。没有想象中的难

( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

请找出其中最小的元素。

你可以假设数组中不存在重复元素。

示例 1:

输入: [3,4,5,1,2]输出: 1示例 2:

输入: [4,5,6,7,0,1,2]输出: 0

intfindMin(vector<int>&nums) {

   if (nums.size() ==1||nums[0]<nums[nums.size()-1]) returnnums[0];

   inthigh=nums.size() -1;

   while(nums[high]<nums[0])

   {

       high--;

   }

   ++high;

   returnnums[high];

}

454. 四数相加 II

给定四个包含整数的数组列表 A , B , C , D ,计算有多少个元组 (i, j, k, l) ,使得 A[i] + B[j] + C[k] + D[l] = 0。

为了使问题简单化,所有的 A, B, C, D 具有相同的长度 N,且 0 ≤ N ≤ 500 。所有整数的范围在 -228 到 228 - 1 之间,最终结果不会超过 231 - 1 。

例如:

输入:A = [ 1, 2]B = [-2,-1]C = [-1, 2]D = [ 0, 2]

输出:2

解释:两个元组如下:

  1. (0, 0, 0, 1) -> A[0] + B[0] + C[0] + D[1] = 1 + (-2) + (-1) + 2 = 0
  2. (1, 1, 0, 0) -> A[1] + B[1] + C[0] + D[0] = 2 + (-1) + (-1) + 0 = 0

思路:建立一个哈希映射,一个记录AB数组的组合和,和为key,出现的次数为value计算CD数组的组合和,得到相反数,若该数存在于key中,即符合要求,将答案加上AB组合和中该数出现的次数(value)

第一版,使用map

intfourSumCount(vector<int>&A, vector<int>&B, vector<int>&C, vector<int>&D) {

   intnum=0,temp=0;

   map<int, int>  sum_map;

   for (autoa : A) {

       for (autob : B) {

           if (sum_map.count(a+b) ==0) sum_map[a+b] =1;

           else

               ++sum_map[a+b];

       }

   }

   for (autoc : C) {

       for (autod : D) {

           temp=-(c+d);

           if (sum_map.count(temp)) num+=sum_map[temp];

       }

   }

   returnnum;  

   }

执行用时 :492 ms, 在所有 C++ 提交中击败了42.54%的用户

内存消耗 :29.3 MB, 在所有 C++ 提交中击败了57.21%的用户

第二版 ,unordered_map

intnum=0,temp=0;

   unordered_map<int, int>  sum_map;

   for (autoa : A) {

       for (autob : B) {

           if (sum_map.count(a+b) ==0) sum_map[a+b] =1;

           else

               ++sum_map[a+b];

       }

   }

   for (autoc : C) {

       for (autod : D) {

           temp=-(c+d);

           if (sum_map.count(temp)) num+=sum_map[temp];

       }

   }

   returnnum;

执行用时 :1822 ms, 在所有 C++ 提交中击败了98.56%的用户

内存消耗 :28.4 MB, 在所有 C++ 提交中击败了57.21%的用户


我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=kgzy88yxhhom


目录
相关文章
|
C# C++
Cool说丨力扣287/792/378
关注博主,获取更多知识
98 0
|
C# C++ 索引
Cool说丨力扣162
162. 寻找峰值
87 0
|
存储 C# C++
Cool说丨力扣29/34
关注博主。获取更多知识
100 0
|
存储 C# C++
Cool说丨力扣392
392. 判断子序列
68 0
|
C# C++
Cool说丨力扣744、704
744. 寻找比目标字母大的最小字母 704. 二分查找
99 0
|
C#
Cool说丨力扣475
475. 供暖器
109 0
|
机器学习/深度学习 算法 C#
Cool说丨力扣202
202. 快乐数
96 0
|
C#
Cool说丨力扣167
167. 两数之和 II - 输入有序数组
66 0
|
C# C++
Cool说丨力扣374、441
441. 排列硬币 374. 猜数字大小
82 0
|
C# C++
Cool说丨力扣367
367. 有效的完全平方数
173 0