二分查找的一个小问题

发布于 2022-09-12 12:57:03 字数 2130 浏览 23 评论 0

首先给出可以运行代码:

#include <cstdio>
#include <algorithm>

using namespace std;

int binarySearch(int left,int right,int num,int coins[]){
    int mid;
    while (left<=right){
        mid = left + (right-left)/2;
        if(coins[mid]==num){
            return mid;
        } else if (coins[mid]<num){
            left = mid+1;
        } else {
            right = mid-1;
        }
    }
    return -1;
}

int main(){
    int N,M;
    scanf("%d %d",&N,&M);
    int coins[N];
    for(int i=0;i<N;++i){
        scanf("%d",&coins[i]);
    }
    sort(coins,coins+N);
    for (int j = 0; j < N; ++j) {
        int mid;
        int pos = binarySearch(0,N-1,M-coins[j],coins);
        if(pos!=-1&&pos!=j){
            printf("%d %d",coins[j],coins[pos]);
            return 0;
        }
    }
    printf("No Solution");
    return 0;
}

测试用例:

7 14
1 8 7 2 4 11 15

输出结果:

No Solution

问题代码如下:

#include <cstdio>
#include <algorithm>

using namespace std;

int main(){
    int N,M;
    scanf("%d %d",&N,&M);
    int coins[N];
    for(int i=0;i<N;++i){
        scanf("%d",&coins[i]);
    }
    sort(coins,coins+N);
    for (int j = 0; j < N; ++j) {
        //对于coins[j],查找M-coins[j]==coins[k]的k并且k!=j
        int left=0,right=N-1;
        int mid;
        int num = M-coins[j];
        while (left<=right){
            mid = left + (right-left)/2;
            if(coins[mid]==num){
                if(mid!=j){
                    printf("%d %d",coins[j],coins[mid]);
                    return 0;
                }
            } else if (coins[mid]<num){
                left = mid+1;
            } else {
                right = mid-1;
            }
        }
    }
    printf("No Solution");
    return 0;
}

疑问点:

在这里我将二分查找的代码放在循环内部就出现运行卡死的情况,如果将其提出成为函数,就可以正常运行,不知道是什么原因。

题目来源:

https://pintia.cn/problem-set...

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

懷念過去 2022-09-19 12:57:03

已经找到问题所在了,确实是不应该将业务逻辑写在算法之中,主要还是因为没有判断其他的逻辑。
修正代码如下:

#include <cstdio>
#include <algorithm>

using namespace std;

int main(){
    int N,M;
    scanf("%d %d",&N,&M);
    int coins[N];
    for(int i=0;i<N;++i){
        scanf("%d",&coins[i]);
    }
    sort(coins,coins+N);
    for (int j = 0; j < N; ++j) {
        //对于coins[j],查找M-coins[j]==coins[k]的k并且k!=j
        int left=0,right=N-1;
        int mid;
        int num = M-coins[j];
        int k = -1;
        while (left<=right){
            mid = left + (right-left)/2;
            if(coins[mid]==num){
                k = mid;
                break;
            } else if (coins[mid]<num){
                left = mid+1;
            } else {
                right = mid-1;
            }
        }
        if(k!=j&&k!=-1){
            printf("%d %d",coins[j],coins[k]);
            return 0;
        }
    }
    printf("No Solution");
    return 0;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文