// 面试题53(一):数字在排序数组中出现的次数
// 题目:统计一个数字在排序数组中出现的次数。例如输入排序数组{1, 2, 3, 3,
// 3, 3, 4, 5}和数字3,由于3在这个数组中出现了4次,因此输出4。 #include <iostream> int GetFirstK(const int* data, int length, int k, int start, int end);
int GetLastK(const int* data, int length, int k, int start, int end); int GetNumberOfK(const int* data, int length, int k)
{
int number = ; if (data != nullptr && length > )
{
int first = GetFirstK(data, length, k, , length - );//得到第一个k的位置
int last = GetLastK(data, length, k, , length - );//得到最后第一个k的位置 if (first > - && last > -)
number = last - first + ;//因为是排序好的,所以直接求其中个数
} return number;
} // 找到数组中第一个k的下标。如果数组中不存在k,返回-1
int GetFirstK(const int* data, int length, int k, int start, int end)
{
if (start > end)//没找到第一个k,返回-1
return -; int middleIndex = (start + end) / ;
int middleData = data[middleIndex];//受启发于二分查找 if (middleData == k)//第一种情况,中间值等于k
{
if ((middleIndex > && data[middleIndex - ] != k)//如果中间值左边的值不是k,或者中间值是数组的开头,则它就是第一个k
|| middleIndex == )
return middleIndex;
else
end = middleIndex - ;
}
else if (middleData > k)
end = middleIndex - ;
else
start = middleIndex + ; return GetFirstK(data, length, k, start, end);
} // 找到数组中最后一个k的下标。如果数组中不存在k,返回-1
int GetLastK(const int* data, int length, int k, int start, int end)
{
if (start > end)
return -; int middleIndex = (start + end) / ;
int middleData = data[middleIndex]; if (middleData == k)
{
if ((middleIndex < length - && data[middleIndex + ] != k)
|| middleIndex == length - )
return middleIndex;
else
start = middleIndex + ;
}
else if (middleData < k)
start = middleIndex + ;
else
end = middleIndex - ; return GetLastK(data, length, k, start, end);
} // ====================测试代码====================
void Test(const char* testName, int data[], int length, int k, int expected)
{
if (testName != nullptr)
printf("%s begins: ", testName); int result = GetNumberOfK(data, length, k);
if (result == expected)
printf("Passed.\n");
else
printf("Failed.\n");
} // 查找的数字出现在数组的中间
void Test1()
{
int data[] = { , , , , , , , };
Test("Test1", data, sizeof(data) / sizeof(int), , );
} // 查找的数组出现在数组的开头
void Test2()
{
int data[] = { , , , , , };
Test("Test2", data, sizeof(data) / sizeof(int), , );
} // 查找的数组出现在数组的结尾
void Test3()
{
int data[] = { , , , , , };
Test("Test3", data, sizeof(data) / sizeof(int), , );
} // 查找的数字不存在
void Test4()
{
int data[] = { , , , , , , };
Test("Test4", data, sizeof(data) / sizeof(int), , );
} // 查找的数字比第一个数字还小,不存在
void Test5()
{
int data[] = { , , , , , , };
Test("Test5", data, sizeof(data) / sizeof(int), , );
} // 查找的数字比最后一个数字还大,不存在
void Test6()
{
int data[] = { , , , , , , };
Test("Test6", data, sizeof(data) / sizeof(int), , );
} // 数组中的数字从头到尾都是查找的数字
void Test7()
{
int data[] = { , , , };
Test("Test7", data, sizeof(data) / sizeof(int), , );
} // 数组中的数字从头到尾只有一个重复的数字,不是查找的数字
void Test8()
{
int data[] = { , , , };
Test("Test8", data, sizeof(data) / sizeof(int), , );
} // 数组中只有一个数字,是查找的数字
void Test9()
{
int data[] = { };
Test("Test9", data, sizeof(data) / sizeof(int), , );
} // 数组中只有一个数字,不是查找的数字
void Test10()
{
int data[] = { };
Test("Test10", data, sizeof(data) / sizeof(int), , );
} // 鲁棒性测试,数组空指针
void Test11()
{
Test("Test11", nullptr, , , );
} int main(int argc, char* argv[])
{
Test1();
Test2();
Test3();
Test4();
Test5();
Test6();
Test7();
Test8();
Test9();
Test10();
Test11();
system("pause");
return ;
}

《剑指offer》第五十三题(数字在排序数组中出现的次数)的更多相关文章

  1. 剑指Offer面试题:32.数字在排序数组中出现的次数

    一.题目:数字在排序数组中出现的次数 题目:统计一个数字在排序数组中出现的次数.例如输入排序数组{1,2,3,3,3,3,4,5}和数字3,由于3在这个数组中出现了4次,因此输出4. 二.解题思路 2 ...

  2. 【剑指offer 面试题38】数字在排序数组中出现的次数

    思路: 利用二分查找,分别查找待统计数字的头和尾的下标,最后做差加一即为结果. C++: #include <iostream> #include <vector> using ...

  3. 《剑指offer》面试题53 - I. 在排序数组中查找数字 I

    问题描述 统计一个数字在排序数组中出现的次数. 示例 1: 输入: nums = [5,7,7,8,8,10], target = 8 输出: 2 示例 2: 输入: nums = [5,7,7,8, ...

  4. 《剑指offer》第四题(二维数组中的查找)

    // 二维数组中的查找 // 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按 // 照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个 // 整数,判断数组 ...

  5. 数字在排序数组中出现的次数 牛客网 剑指Offer

    数字在排序数组中出现的次数 牛客网 剑指Offer 题目描述 统计一个数字在排序数组中出现的次数. class Solution: def GetNumberOfK(self, data, k): i ...

  6. 【剑指Offer面试编程题】题目1349:数字在排序数组中出现的次数--九度OJ

    题目描述: 统计一个数字在排序数组中出现的次数. 输入: 每个测试案例包括两行: 第一行有1个整数n,表示数组的大小.1<=n <= 10^6. 第二行有n个整数,表示数组元素,每个元素均 ...

  7. 剑指offer——python【第37题】数字在排序数组中出现的次数

    题目描述 统计一个数字在排序数组中出现的次数 思路 最贱的方法依旧是count计数.. 当然,,看到有序数组就应该想到二分法,找到重复数字左边和右边的数字,然后两个相减就可以了 解答 方法1 coun ...

  8. 【Java】 剑指offer(53-1) 数字在排序数组中出现的次数

    正文 本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 统计一个数字在排序数组中出现的次数.例如输入排序数组{1, ...

  9. 剑指Offer(三十七):数字在排序数组中出现的次数

    剑指Offer(三十七):数字在排序数组中出现的次数 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.n ...

随机推荐

  1. 软件工程 #02# Entity Relationship Diagram VS. 用 UML 中的类图表示 E-R 图

    不同的老师叫我们画 E-R 图居然是不一样的,于是我仔细研究了一番.. 通常所说的 E-R 图(外文全称 Entity Relationship Diagram,简称 ERD)长这个样子: 而有时候它 ...

  2. python通过sftp远程传输文件

    python提供了一个第三方模块paramiko,通过这个模块可以实现两台机器之间的网络连接,sftp是paramiko的一个方法,使用sftp可以在两台机器之间互相传输 拷贝文件.然而paramik ...

  3. mysql误删数据快速恢复

    相信后端研发的同学在开发过程经常会遇到产品临时修改线上数据的需求,如果手法很稳那么很庆幸可以很快完成任务,很不幸某一天突然手一抖把表里的数据修改错误或者误删了,这个时候你会发现各种问题反馈接踵而来.如 ...

  4. suse 12sp1 oracle 11g r2 时出现错误 调用/sysman/lib/ins_emagent.mk的目标nmo时出错

    要因为C库的问题,解决办法就是手动指定C库位置出现agent nmhs问题后,找到$ORACLE_HOME/sysman/lib/ins_emagent.mk文件,在文件里找字符串 $(MK_EMAG ...

  5. TensorFlow学习---tf.nn.dropout防止过拟合

    一. Dropout原理简述: tf.nn.dropout是TensorFlow里面为了防止或减轻过拟合而使用的函数,它一般用在全连接层. Dropout就是在不同的训练过程中随机扔掉一部分神经元.也 ...

  6. C# 给类做事件的一般做法

    https://docs.microsoft.com/zh-cn/dotnet/standard/events/how-to-raise-and-consume-events 第一个示例演示如何引发和 ...

  7. 4698: Sdoi2008 Sandy的卡片

    前言 总之这个东西说起来很麻烦就是了, 思路 差分合并+后缀数组+二分(dddl) 类似于那个bzoj1031的复制子串和那个poj1743的差分 来看个例子 3 5 1 2 3 4 5 4 1 1 ...

  8. Spring-Cache 注解 @Cacheable,@CachePut , @CacheEvict

    1.自动生成key @Bean public KeyGenerator keyGenerator() { return new KeyGenerator() { @Override public Ob ...

  9. 浅谈Java中static关键字、权限修饰符

    1.实例变量:也称非静态成员变量,实例变量前没有static关键字,用来描述同一类事物的公共属性.访问方式:对象名.变量名.实例变量存储在堆区,对象有n个,数据就有n个.实例变量随着对象的创建而创建, ...

  10. ssm项目中遇到微信用户名称带有表情,插入失败问题

    ssm项目中遇到微信用户名称带有表情,插入失败问题 问题 Mysql的utf8编码最多3个字节,而Emoji表情或者某些特殊字符是4个字节. 因此会导致带有表情的昵称插入数据库时出错. 解决方法 一. ...