169. Majority Element--寻找数组中出现次数超过一半的数据,229. Majority Element II--注意最后的检测

本文主要是介绍169. Majority Element--寻找数组中出现次数超过一半的数据,229. Majority Element II--注意最后的检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一题、169. Majority Element-
Given an array of size n, find the majority element. The majority element is the element that appears more than ⌊ n/2 ⌋ times.

You may assume that the array is non-empty and the majority element always exist in the array.
方法一、由于出现一半的数字,则即寻找第middle大的数字,可以基于快速排序的partition的思想,然后找出第Middle大的数字,代码此处省略;
方法二、hash的方法;
方法三、基于出现次数超过一半的数据的特征,代码如下:

int majorityElement(vector<int>& nums) {if(nums.size()<=0)return -1;int count = 1;int result = nums[0];for(int i = 1; i < nums.size(); i++){if(count == 0){result = nums[i];count = 1;}else if(nums[i] == result){count++;}else{count--;}}return result;}

第二题、229. Majority Element II
Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorithm should run in linear time and in O(1) space.

/*求众数的问题观察可知,数组中至多可能会有2个出现次数超过 ⌊ n/3 ⌋ 的众数;记变量num1, num2为候选众数; cnum1, cnum2为它们对应的出现次数遍历数组,记当前数字为num若num与num1或num2相同,则将其对应的出现次数加1否则,若cnum1或cnum2为0,则将其置为1,对应的候选众数置为num否则,将cnum1与cnum2分别减1最后,再统计一次候选众数在数组中出现的次数,若满足要求,则返回之。*/vector<int> majorityElement(vector<int>& nums) {int len = nums.size();if(len <= 0){return (vector<int> ());}int num1 = 0,num2 = 1;int cnum1 = 0,cnum2 = 0;for(int i = 0; i < len; i++){if(nums[i] == num1){cnum1++;}else if(nums[i] == num2){cnum2++;}else if(cnum1 == 0){num1 = nums[i];cnum1 = 1;}else if(cnum2 == 0){num2 = nums[i];cnum2 = 1;}else{cnum1--;cnum2--;}}cnum1 = 0;cnum2 = 0;for(int i = 0; i < len; i++){if(nums[i] == num1){cnum1++;}else if(nums[i] == num2){cnum2++;}}vector<int> result;if(cnum1 > len / 3){result.push_back(num1);}if(cnum2 > len / 3){result.push_back(num2);}return result;}

这篇关于169. Majority Element--寻找数组中出现次数超过一半的数据,229. Majority Element II--注意最后的检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

C++ Primer 多维数组的使用

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

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate