zoukankan      html  css  js  c++  java
  • 剑指offer 38_统计数组中k出现的个数

    思路:

    二分法,分别找出第一个和最后一个k出现的位置。相减 加一

    #include <stdio.h>
    
    //获取第一个K的位置 int getFirstK (int k,int *numbers,int start,int end){ if(start > end){ return -1; } int middle = (start + end) / 2; int middleData = numbers[middle]; if(middleData < k){ start = middle + 1; }else if(middleData > k){ end = middle - 1; }else{ if(middle>0 && numbers[middle-1]!=k    //注意这个if || middle==0){ return middle; }else{ end = middle -1; } } getFirstK(k,numbers,start,end); }
    //获取最后一个K的位置
    int getLastK (int k,int *numbers,int start,int end){ if(start > end){ return -1; } int middle = (start + end) / 2; int middleData = numbers[middle]; if(middleData < k){ start = middle + 1; }else if(middleData > k){ end = middle - 1; }else{ if(middle<end && numbers[middle+1]!=k || middle==end){ return middle; }else{ start = middle + 1; } } getLastK(k,numbers,start,end); } //得到k 在numbers中的个数 int getNumberOfK(int k, int* numbers,int length){ if(numbers == NULL || length <= 0){ return 0; } int last = getLastK(k, numbers,0, length-1); int first = getFirstK(k, numbers,0, length-1); if(last == -1 || first == -1){ return 0; } return last - first + 1; } int main(){ int numbers1[20] = {1,1,1,2,3,3,3,3,3,3,3,3,4,5,6,7,66,7787,8888,9999}; printf("%d ",getNumberOfK(3,numbers1,20)); int numbers2[10] = {1,2,2,2,2,5,6,7,8,9}; printf("%d ",getNumberOfK(3,numbers2,10)); int* numbers3 = NULL; printf("%d ",getNumberOfK(3,numbers3,10)); }
  • 相关阅读:
    2015PPTV校招笔试详解
    2015华数校招笔试详解
    2015我的校招之路
    2015美团校招笔试试题
    关于联想超极本装入Ubuntu系统无法开启无线硬件开关的解决
    RabbitMQ
    office 2016 for mac 下拉框 无法展开问题
    mac 下 tomcat7的安装
    mac 10.11.6,Xcode8下,ruby2.3安装,Cocoapods安装~
    学习的学习的方法
  • 原文地址:https://www.cnblogs.com/maxiaodoubao/p/4738675.html
Copyright © 2011-2022 走看看