为什么华为在亲戚长辈面前风评这么好。

科技   2025-01-01 12:09   重庆  
一网友说为什么华子在亲戚长辈面前风评那么好,一听说签了华为都认为是年薪百万。在华为年薪百万也不是不可能,但至少要18级以上。大约7、8年能升到16级,再往上升就较难。18级以下占比最多,18级是个坎,往上升需要重新考评,答辩。如果没有特殊招聘,一般需要十年以上的时间才能达到18级,也就相当于35岁之后了。







--------------下面是今天的算法题--------------


来看下今天的算法题,这题是LeetCode的第162题:寻找峰值。


问题描述



来源:LeetCode第162题
难度:中等

峰值元素是指其值严格大于左右相邻值的元素。给你一个整数数组 nums,找到峰值元素并返回其索引。

数组可能包含多个峰值,在这种情况下,返回 任何一个峰值所在位置即可。你可以假设 nums[-1] = nums[n] = -∞ 。

你必须实现时间复杂度为 O(log n) 的算法来解决此问题。

示例1:

输入:nums = [1,2,3,1]

输出:2

解释:3 是峰值元素,你的函数应该返回其索引 2。

示例2:

输入:nums = [1,2,1,3,5,6,4]

输出:1 或 5

解释:你的函数可以返回索引 1,其峰值元素为 2;

     或者返回索引 5, 其峰值元素为 6。


  • 1 <= nums.length <= 1000

  • -2^31 <= nums[i] <= 2^31 - 1

  • 对于所有有效的 i 都有 nums[i] != nums[i + 1]


问题分析



这题让找出数组中的峰值,因为nums[-1] = nums[n] = -∞ ,也就是默认数组两边的值(实际上是不存在的)是负无穷大,所以数组中肯定是有峰值的。如果没有时间复杂度的限制,这题就是一道非常简单的题,直接遍历数组中的每个值然后与两边比较即可。

但这题要求的时间复杂度是O(log n) ,所以我们只能使用二分查找,每次用中间的值nums[mid]和它的下一个值nums[mid+1]比较哪个大,因为提示中说了对于所有有效的 i 都有 nums[i] != nums[i + 1],所以大的那边一定有峰值。

JAVA:
public int findPeakElement(int[] nums) {
    int left = 0;
    int right = nums.length - 1;
    while (left < right) {
        int mid1 = (left + right) >>> 1;
        int mid2 = mid1 + 1;
        if (nums[mid1] < nums[mid2])
            left = mid2;// 右边肯定有峰值
        else
            right = mid1;// 左边肯定有峰值
    }
    return left;
}

C++:
public:
    int findPeakElement(vector<int>& nums) {
        int left = 0;
        int right = nums.size() - 1;
        while (left < right) {
            int mid1 = left +(right-left)/2;
            int mid2 = mid1 + 1;
            if (nums[mid1] < nums[mid2])
                left = mid2;// 右边肯定有峰值
            else
                right = mid1;// 左边肯定有峰值
        }
        return left;
    }

Python:
def findPeakElement(self, nums: List[int]) -> int:
    left, right = 0, len(nums) - 1
    while left < right:
        mid1 = left + ((right - left) >> 1)
        mid2 = mid1 + 1
        if nums[mid1] < nums[mid2]:
            left = mid2  # 右边肯定有峰值
        else:
            right = mid1  # 左边肯定有峰值
    return left

猿大侠
猿大侠,带你用大侠的视角挖掘程序员、科技、数码、互联网、软硬件资讯,一起学习技术,每天中午12:08,我们不见不散!
 最新文章