升序数组中求一个key出现的次数

2023-10-08 14:48
文章标签 数组 次数 key 中求 升序

本文主要是介绍升序数组中求一个key出现的次数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

算法思路: 在排好序的数组,相同的数字是排列在一起的,所以只需要找到key的左边界和右边界即可。

找左边界可以看成是找数组中第一个大于等于key的数的位置,找右边界可以看成是找最后一个小于等于key的数。

复杂度分析:时间复杂度是O(log(n)),空间复杂度是O(n)。

 

#include <stdio.h>
/** @brief 在升序数组a中找到第一个大于等于key的数的位置,如果不存在这样的位置,例如* 数组a中所有的数字都比key小,则返回的数是n* @parma int* a 升序数组* @parma int n  数组a的长度* @int key 待查找的关键字*/
int find_left(int* a, int n, int key){int l, r, mid; l = 0; r = n-1;while(l <= r){int mid = (l+r) >> 1; if(a[mid] >= key) r=mid-1; else l=mid+1; }return r+1; 
}/** @brief 在升序数组a中找到最后一个小于等于key的数的位置,如果不存在这样的位置,例如* 数组a中所有的数字都比key大,则返回的数是-1* @parma int* a 升序数组* @parma int n  数组a的长度* @int key 待查找的关键字*/
int find_right(int* a, int n, int key){int l, r, mid; l = 0; r = n-1;while(l <= r){int mid = (l+r)>>1; if(a[mid] <= key) l = mid + 1; else r = mid - 1; }    return l-1; 
}
int count(int* a, int n, int key){int l = find_left(a, n, key);int r = find_right(a, n, key);int cnt = r-l+1; return cnt; 
}
int main(){//输入和输出重定向freopen("in.txt","r", stdin);freopen("out.txt", "w", stdout);const int N = 4; int a[N] = {2, 4, 4, 5}, key; //use case 1:key比数组中所有的数都要小key = 1; printf("%d出现的次数是%d\n", key, count(a, N, key));//use case 2:key在数组出现了一次key = 2; printf("%d出现的次数是%d\n", key, count(a, N, key));//use case 3:key在数组出现了不止一次key = 4; printf("%d出现的次数是%d\n", key, count(a, N, key));//use case 4:key不在数组中,但大于数组中的最小数,小于数组中的最大数key = 3; printf("%d出现的次数是%d\n", key, count(a, N, key));//use case 5:key比数组中的最大数还大key = 6; printf("%d出现的次数是%d\n", key, count(a, N, key));return 0; 
}

 输出结果如下:

1出现的次数是0

2出现的次数是1

4出现的次数是2

3出现的次数是0

6出现的次数是0

 

这篇关于升序数组中求一个key出现的次数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

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

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

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、方