面试经典算法系列之数组/字符串2 -- 多数元素

2024-04-24 08:52

本文主要是介绍面试经典算法系列之数组/字符串2 -- 多数元素,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

面试经典算法题34-多数元素

LeetCode.169
阿Q技术站

问题描述

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 1:

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

示例 2:

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

思路

  1. 初始化候选多数元素 candidate 和其出现次数 count
  2. 遍历数组,对于每个元素:
    • 如果 count 为0,则将当前元素设为候选多数元素,并将 count 设为1。
    • 否则,如果当前元素等于候选多数元素,则将 count 加1,否则将 count 减1。
  3. 返回候选多数元素 candidate

图解

阿Q作

参考代码

C++
#include <iostream>
#include <vector>using namespace std;class Solution {
public:int majorityElement(vector<int>& nums) {int candidate = nums[0]; // 初始化候选多数元素为数组第一个元素int count = 1; // 初始化候选多数元素的出现次数为1// 遍历数组for (int i = 1; i < nums.size(); ++i) {if (count == 0) {candidate = nums[i]; // 更新候选多数元素count = 1; // 重置出现次数为1} else if (nums[i] == candidate) {count++; // 候选多数元素出现,增加出现次数} else {count--; // 候选多数元素未出现,减少出现次数}}return candidate; // 返回候选多数元素}
};int main() {vector<int> nums = {3, 2, 3}; // 输入数组Solution solution;int result = solution.majorityElement(nums); // 查找多数元素cout << "多数元素:" << result << endl; // 输出结果return 0;
}
Java
import java.util.*;class Solution {public int majorityElement(int[] nums) {int candidate = nums[0]; // 初始化候选多数元素为数组第一个元素int count = 1; // 初始化候选多数元素的出现次数为1// 遍历数组for (int i = 1; i < nums.length; ++i) {if (count == 0) {candidate = nums[i]; // 更新候选多数元素count = 1; // 重置出现次数为1} else if (nums[i] == candidate) {count++; // 候选多数元素出现,增加出现次数} else {count--; // 候选多数元素未出现,减少出现次数}}return candidate; // 返回候选多数元素}public static void main(String[] args) {int[] nums = {3, 2, 3}; // 输入数组Solution solution = new Solution();int result = solution.majorityElement(nums); // 查找多数元素System.out.println("多数元素:" + result); // 输出结果}
}
Python
from typing import Listclass Solution:def majorityElement(self, nums: List[int]) -> int:candidate = nums[0] # 初始化候选多数元素为数组第一个元素count = 1 # 初始化候选多数元素的出现次数为1# 遍历数组for i in range(1, len(nums)):if count == 0:candidate = nums[i] # 更新候选多数元素count = 1 # 重置出现次数为1elif nums[i] == candidate:count += 1 # 候选多数元素出现,增加出现次数else:count -= 1 # 候选多数元素未出现,减少出现次数return candidate # 返回候选多数元素# 测试
nums = [3, 2, 3] # 输入数组
solution = Solution()
result = solution.majorityElement(nums) # 查找多数元素
print("多数元素:", result) # 输出结果

这篇关于面试经典算法系列之数组/字符串2 -- 多数元素的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/931294

相关文章

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -