题解 | #数字在升序数组中出现的次数#

数字在升序数组中出现的次数

http://www.nowcoder.com/practice/70610bf967994b22bb1c26f9ae901fa2

/**
 * 
 * @param data int整型一维数组 
 * @param dataLen int data数组长度
 * @param k int整型 
 * @return int整型
 *
 * C语言声明定义全局变量请加上static,防止重复定义
 */
int GetNumberOfK(int* data, int dataLen, int k ) {                                             //简单粗暴的思路,先找到目标target值的任意一个位置,再分别往左往右找
    int start=0,end=dataLen-1;
    int left=0,right=1;
    for(int i=start;i<=end;i++){
    int mid=(start+end)/2;
    if(data[mid]>k){
    end=mid;
}
if(data[mid]<k){
start=mid;
}
if(data[mid]==k){                                             //找到值的时候记得break;
left=mid;
right=mid;
printf("mid=%d\n",mid);
while(data[left]==k){
left--;
}
while(data[right]==k){
right++;
}
printf("left=%d right=%d\n",left,right);
break;
}
}
return right-left-1;
}
全部评论

相关推荐

找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务