面试经典算法系列之数组/字符串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

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.