剑指offer37:统计一个数字在排序数组中出现的次数

本文介绍两种高效算法:二分查找与STL库函数,用于统计排序数组中特定数字的出现频率。通过实现C++代码,展示了如何利用二分查找达到O(logn)的时间复杂度,并利用lower_bound与upper_bound函数简化代码。

1 题目描述

  统计一个数字在排序数组中出现的次数。

2 思路和方法

  (1)查找有序数组,首先考虑使用二分查找,使时间复杂度为O(log n)。更改二分查找的条件,不断缩小区间,直到区间头和区间尾均为k时停止,计算得到区间长度。O(n*log(n))。

  (2)两行代码就搞定,就是用C++ stl里面的lower_boundupper_bound,lower_bound是找出不小于即大于等于的第一个数的下标 ;upper_bound是找出大于的第一个数的下标

3 C++核心代码

(1)

 1 class Solution {
 2 public: // 二分查找 O(log n)
 3     int GetNumberOfK(vector<int> data ,int k) {
 4         if (data.size() <=0)
 5             return 0;
 6         int count = 0;
 7         int begin = 0;
 8         int end = data.size()- 1;
 9 
10         while (begin<=end){
11             int mid = (begin + end) /2;
12             if (data[begin]==k && data[end] == k)
13                 break;
14 
15             // 缩小start和end的范围,使start指向第一个k,end指向最后一个k
16             if (data[begin] < k)
17                 ++begin;
18             if (data[end] > k)
19                 --end;
20 
21             if (data[mid]< k){
22                 end = mid -1;
23             } else if (data[mid] > k){
24                 begin = mid +1;
25             }
26         }
27         if (data[begin] ==k && data[end]==k)
28             return end - begin +1 ; // beg和end分别对应第一个和最后一个k所在位置
29         else
30             return 0;     // beg>end 不存在该元素
31 
32     }
33 };
View Code

(2)

 1 class Solution 
 2 {
 3 public:
 4     int GetNumberOfK(vector<int> data ,int k)
 5     {
 6         int s1 = lower_bound(data.begin(),data.end(),k)-data.begin();
 7         int s2 = upper_bound(data.begin(),data.end(),k)-data.begin();
 8         //cout<<s1<<" "<<s2<<endl;
 9         return s2-s1;
10     }
11 };
View Code

参考资料

https://blog.youkuaiyun.com/zjwreal/article/details/88774692

转载于:https://www.cnblogs.com/wxwhnu/p/11421309.html

代码转载自:https://pan.quark.cn/s/7f503284aed9 Hibernate的核心组件总数达到五个,具体包括:Session、SessionFactory、Transaction、Query以及Configuration。 这五个核心组件在各类开发项目中都具有普遍的应用性。 借助这些组件,不仅可以高效地进行持久化对象的读取与存储,还能够实现事务管理功能。 接下来将通过图形化的方式,逐一阐述这五个核心组件的具体细节。 依据所提供的文件内容,可以总结出以下几个关键知识点:### 1. SSH框架详细架构图尽管标题提及“SSH框架详细架构图”,但在描述部分并未直接呈现关于SSH的详细内容,而是转向介绍了Hibernate的核心接口。 然而,在此我们可以简要概述SSH框架(涵盖Spring、Struts、Hibernate)的核心理念及其在Java开发中的具体作用。 #### Spring框架- **定义**:Spring框架是一个开源架构,其设计目标在于简化企业级应用的开发流程。 - **特点**: - **分层结构**:该框架允许开发者根据实际需求选择性地采纳部分组件,而非强制使用全部功能。 - **可复用性**:Spring框架支持创建可在不同开发环境中重复利用的业务逻辑和数据访问组件。 - **核心构成**: - **核心容器**:该部分包含了Spring框架的基础功能,其核心在于`BeanFactory`,该组件通过工厂模式运作,并借助控制反转(IoC)理念,将配置和依赖管理与具体的应用代码进行有效分离。 - **Spring上下文**:提供一个配置文件,其中整合了诸如JNDI、EJB、邮件服务、国际化支持等企业级服务。 - **Spring AO...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值