【LetMeFly】1287.有序数组中出现次数超过25%的元素:遍历
力扣题目链接:https://leetcode.cn/problems/element-appearing-more-than-25-in-sorted-array/
给你一个非递减的 有序 整数数组,已知这个数组中恰好有一个整数,它的出现次数超过数组元素总数的 25%。
请你找到并返回这个整数
示例:
输入:arr = [1,2,2,6,6,6,6,7,10]
输出:6
提示:
1 <= arr.length <= 10^4
0 <= arr[i] <= 10^5
解题方法:遍历
对于长度为$n$的有序数组,对于一个首次出现下标为$i$的数:
整个数出现次数超过了$25%$ 等价于 下标$\lfloor\frac{n}{4}\rfloor+i$仍为这个数。
- 时间复杂度$O(len(arr))$
- 空间复杂度$O(1)$
AC代码
C++
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
|
class Solution { public: int findSpecialInteger(vector<int>& arr) { int locDiff = arr.size() / 4; for (int i = 0; 1; i++) { if (arr[i] == arr[i + locDiff]) { return arr[i]; } } } };
|
Python
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| ''' Author: LetMeFly Date: 2025-02-17 14:38:57 LastEditors: LetMeFly.xyz LastEditTime: 2025-02-17 14:43:22 ''' from typing import List
class Solution: def findSpecialInteger(self, arr: List[int]) -> int: locDiff = len(arr) // 4 for i in range(len(arr)): if arr[i] == arr[i + locDiff]: return arr[i] return -1
|
Java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
|
class Solution { public int findSpecialInteger(int[] arr) { int locDiff = arr.length / 4; for (int i = 0; true; i++) { if (arr[i] == arr[i + locDiff]) { return arr[i]; } } } }
|
Go
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
|
package main
func findSpecialInteger(arr []int) int { locDiff := len(arr) / 4 for i := 0; true; i++ { if arr[i] == arr[i + locDiff] { return arr[i] } } return -1 }
|
同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
千篇源码题解已开源
Tisfy:https://blog.letmefly.xyz/2025/02/17/LeetCode 1287.有序数组中出现次数超过25的元素