题解 | #查找#

查找

https://www.nowcoder.com/practice/d93db01c2ee44e8a9237d63842aca8aa

#include <iostream>
#include "cstdio"
#include "algorithm"
using namespace std;
bool BinarySearch(int arr[], int left, int right, int x) {
    int mid;
    while (left <= right) {
        mid = (left + right) / 2;
        if (arr[mid] == x)
            return true;
        if (arr[mid] > x) {
            right = mid - 1;
        } else
            left = mid + 1;

    }
    return false;
}
int main() {
    int n;
    scanf("%d", &n);
    int arr[n];
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }

    sort(arr, arr + n); ///二分查找需要有序数组

    int m;
    scanf("%d", &m);
    int integer[m];
    for (int i = 0; i < m; i++) {
        scanf("%d", integer + i);
    }
    for (int i = 0; i < m; i++) {
        if (BinarySearch(arr, 0, n - 1, integer[i]))
            printf("%s\n", "YES");
        else
            printf("%s\n", "NO");
    }



    return 0;
}

全部评论

相关推荐

10-22 12:03
山东大学 Java
程序员小白条:26届一般都得有实习,项目可以随便写的,如果不是开源社区的项目,随便包装,技术栈也是一样,所以本质应该找学历厂,多投投央国企和银行,技术要求稍微低一点的,或者国企控股那种,纯互联网一般都得要干活
应届生简历当中,HR最关...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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