博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
剑指offer——面试题38:数字在排序数组中出现的次数
阅读量:4087 次
发布时间:2019-05-25

本文共 1412 字,大约阅读时间需要 4 分钟。

int GetFirstK(int* data, int length, int k, int start, int end){    if(start > end)        return -1;    int middleIndex = (start + end) / 2;    int middleData = data[middleIndex];    if(middleData == k)    {        if((middleIndex > 0 && data[middleIndex - 1] != k)             || middleIndex == 0)            return middleIndex;        else            end  = middleIndex - 1;    }    else if(middleData > k)        end = middleIndex - 1;    else        start = middleIndex + 1;    return GetFirstK(data, length, k, start, end);}

int GetLastK(int* data, int length, int k, int start, int end){    if(start > end)        return -1;    int middleIndex = (start + end) / 2;    int middleData = data[middleIndex];    if(middleData == k)    {        if((middleIndex < length - 1 && data[middleIndex + 1] != k)             || middleIndex == length - 1)            return middleIndex;        else            start  = middleIndex + 1;    }    else if(middleData < k)        start = middleIndex + 1;    else        end = middleIndex - 1;    return GetLastK(data, length, k, start, end);}

int GetNumberOfK(int* data, int length, int k){    int number = 0;    if(data != NULL && length > 0)    {        int first = GetFirstK(data, length, k, 0, length - 1);        int last = GetLastK(data, length, k, 0, length - 1);                if(first > -1 && last > -1)            number = last - first + 1;    }    return number;}

你可能感兴趣的文章
Flutter 混合开发框架模式探索
查看>>
Flutter 核心原理与混合开发模式
查看>>
Flutter Boost的router管理
查看>>
Android Flutter混合编译
查看>>
微信小程序 Audio API
查看>>
[React Native]react-native-scrollable-tab-view(进阶篇)
查看>>
Vue全家桶+Mint-Ui打造高仿QQMusic,搭配详细说明
查看>>
React Native for Android 发布独立的安装包
查看>>
React Native应用部署/热更新-CodePush最新集成总结(新)
查看>>
react-native-wechat
查看>>
基于云信的react-native聊天系统
查看>>
网易云音乐移动客户端Vue.js
查看>>
ES7 await/async
查看>>
ES7的Async/Await
查看>>
React Native WebView组件实现的BarCode(条形码)、(QRCode)二维码
查看>>
每个人都能做的网易云音乐[vue全家桶]
查看>>
JavaScript专题之数组去重
查看>>
Immutable.js 以及在 react+redux 项目中的实践
查看>>
Vue2.0全家桶仿腾讯课堂(移动端)
查看>>
React+Redux系列教程
查看>>