国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

數字在排序數組中出現的次數

2019-11-10 21:34:35
字體:
來源:轉載
供稿:網友

統計一個數字在排序數組中出現的次數。

IDEA

1.簡單粗暴,遍歷

2.排序數組->數組元素有序->二分查找到這個數字,然后依次上前向后查找出最前一個和最后一個相同元素(因為數組是排序數組,是有序的,這個數字在該數組中連續出現)

CODE

1.

public class Solution {    public int GetNumberOfK(int [] array , int k) {       int count=0;        for(int i=0;i<array.length;i++){            if(array[i]==k){                count++;            }        }        return count;    }}2.

public class Solution {    public int GetNumberOfK(int [] array , int k) {        if(array.length==0||array==null){            return 0;        }        int low=0,high=array.length-1;        int index=-1;        while(low<=high){            int mid=(low+high)>>1;            if(array[mid]==k){                index=mid;                break;            }else if(array[mid]>k){                high=mid-1;            }else{                low=mid+1;            }        }        if(index==-1){            return 0;        }        low=index-1;        high=index+1;        while(low>=0&&array[low]==k){            low--;        }        while(high<array.length&&array[high]==k){            high++;        }        return high-low-1;    }}


上一篇:PAT甲級1068

下一篇:UGUI文字打印效果

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 博野县| 蓝山县| 宁南县| 宜宾县| 平山县| 新宁县| 霸州市| 福海县| 清水县| 余干县| 长治县| 上杭县| 嫩江县| 兴文县| 大同县| 醴陵市| 板桥市| 齐齐哈尔市| 封丘县| 新兴县| 田东县| 安顺市| 揭阳市| 京山县| 临武县| 库伦旗| 西宁市| 沙坪坝区| 施秉县| 沂水县| 乌海市| 江口县| 内丘县| 金华市| 奉节县| 苍溪县| 龙川县| 张家港市| 达拉特旗| 昆山市| 四平市|