// 面试题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. centos6安装多实例mysql

    centos 6.5,使用二进制安装多实例mysql 5.5.60 所需安装包mysql-5.5.60-linux-glibc2.12-x86_64.tar.gz.ncurses-devel-5.7- ...

  2. fjwc2019 D1T2 原样输出(后缀自动机+dp)

    #179. 「2019冬令营提高组」原样输出 暴力对每个串建后缀自动机,然后暴力枚举每个自动机的子串.可以拿到部分分. 然鹅我们可以把每个后缀自动机连起来. 我们知道,后缀自动机是用最少的点(空间)表 ...

  3. 2018-2019-1 20189206 《Linux内核原理与分析》第四周作业

    linux内核分析学习笔记 --第三章 MenuOS的构造 计算机的"三大法宝"和操作系统的"两把宝剑" 三大法宝 程序存储计算机 即冯诺依曼体系结构,基本上是 ...

  4. 快速阅读《QT5.9 c++开发指南》2

    1.sample2_2 信号和槽 MFC中最让人印象深刻的就是"消息映射",这里有理由相信,"信号和槽"是这种功能的发扬和扩展.通过简单的 connect(ui ...

  5. 《学习OpenCV3》第6章课后习题

    //Exercises at end of Chapter 5,<learning OpenCV3> #include "stdafx.h" #include < ...

  6. ScheduledTheadPool线程池的使用

    ScheduledTheadPool线程池的特点在于可以延迟执行任务,也可以周期性执行任务. 创建线程池 ScheduledExecutorService scheduled = Executors. ...

  7. ODAC(V9.5.15) 学习笔记(六)TOraSQL、TOraTable和TOraStoredProc

    TOraSQL是一个SQL语句执行控件,包括PL/SQL块等,不返回数据集结果. 名称 类型 说明 ChangeCursor Boolean 在非阻塞模式下是否允许改变屏幕的光标 WaitExecut ...

  8. Python3基础 list enumerate 将列表的每个元素转换成 带索引值的元组

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  9. IQR(Inter-Quartile Range)

    IQR(Inter-Quartile Range)在统计中叫内距.内距又称为四分位差.具体如下:内距IQR即Inter-Quartile Range, 这是统计技术上的名词.内距又称为四分位差,是两个 ...

  10. 给大家分享两套WordPress收费主题

    主题一:No.7 – 极简 by 大当家 1.主题网址:http://qzhai.net/2016-03-546.html 2.主题预览:http://qzhai.net/000/?theme=No. ...