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

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

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

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param nums int整型一维数组
 * @param numsLen int nums数组长度
 * @param k int整型
 * @return int整型
 */
#include <stdio.h>
#include <stdlib.h>

int GetNumberOfK(int* data, int dataLen,
                 int k ) {  //先找到目标target值的任意一个位置,再分别往左往右找
    int mid = 0;
    int start = 0;
    int end = dataLen - 1;
    int left = 0 ;
    int right = 1;
    for (int i = start; i <= end; i++) {
        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;
}

全部评论
函数名为GetNumberOfK。函数接受三个参数:data是一个整型数组指针,dataLen是数组的长度,k是要查找的目标值。 函数的目标是统计数组中目标值k出现的次数,并返回该次数。函数的实现思路如下: 初始化变量mid、start和end,分别表示当前搜索范围的中间位置、起始位置和结束位置。 初始化变量left和right,分别表示目标值k的左边界和右边界。 使用二分查找的思路,在数组中找到目标值k的任意一个位置。 如果data[mid]大于k,将end更新为mid。 如果data[mid]小于k,将start更新为mid。 如果data[mid]等于k,表示找到目标值,将left和right初始化为mid。 在找到目标值的位置后,分别向左和向右遍历数组,找到目标值k的左边界和右边界。 当data[left]等于k时,向左移动left。 当data[right]等于k时,向右移动right。 返回右边界right减去左边界left再减去1,即为目标值k在数组中出现的次数。
点赞 回复 分享
发布于 2023-08-25 17:53 上海

相关推荐

04-08 10:36
已编辑
华南理工大学 C++
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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