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

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

C#从XmlDocument提取完整字符串的方法

《C#从XmlDocument提取完整字符串的方法》文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,... 方法1:通过XMLDocument的OuterXml属性,见XmlDocument类该方法获得的xm

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2