// 面试题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. django模板-if标签和for标签

    在django中,标签写在{%  标签  %}中 if else标签 ①通过if进行条件判断 views.py from django.shortcuts import render def inde ...

  2. Django Form&ModelForm

    ModelForm: 首先导入所需模块 from django.forms import ModelFormfrom django.forms import widgets as form_widge ...

  3. 升级到0.9 log4jmongodb(mongo-java-driver 3.x)后,报No server chosen by WritableServerSelector from cluster description ClusterDescription

    接上一篇http://www.cnblogs.com/zhjh256/p/6690003.html. 17-04-11 13:47:54.676 INFO cluster-ClusterId{valu ...

  4. spring boot 结合Redis 实现工具类

    自己整理了 spring boot 结合 Redis 的工具类引入依赖 <dependency> <groupId>org.springframework.boot</g ...

  5. ODAC(V9.5.15) 学习笔记(四)TCustomDADataSet(2)

    2.连接相关 名称 类型 说明 Connection 指向一个数据库连接对象 Disconnected 设置为True将在数据库关闭后继续保持数据集的开启状态. 3. 数据获取 名称 类型 说明 Fe ...

  6. linux下如何调试Makefile?

    答:make --debug=all (输出所有的调试信息)

  7. 【做题】TCSRM592 Div1 500 LittleElephantAndPermutationDiv1——计数&dp

    题意:定义函数\(f(A,B) = \sum_{i=1}^n \max(A_i,B_i)\),其中\(A\)和\(B\)都是长度为\(n\)的排列.给出\(n\)和\(k\),问有多少对\((A,B) ...

  8. 【做题】arc072_f-Dam——维护下凸包

    题意:有一个容量为\(L\)的水库,每天晚上可以放任意体积的水.每天早上会有一定温度和体积的水流入水库,且要保证流入水之后水的总体积不能超过\(L\).令体积分别为\(V_1,V_2\),温度分别为\ ...

  9. 编译 glibc-2.14 时出现的一个LD_LIBRARY_PATH不路径bug

    ../configure --prefix=/home/zzhy/wd/software/glibc-2.14 错误:checking LD_LIBRARY_PATH variable... cont ...

  10. 用原型封装一个操作DOM的例子

    <script> // 一句话 在构造函数里面写属性 在原型里面写方法 function Elem(d){ this.even=document.getElementById(d); } ...