gpt4 book ai didi

C 二分和线性搜索

转载 作者:行者123 更新时间:2023-11-30 20:10:17 25 4
gpt4 key购买 nike

您好,我想绘制二进制和线性搜索算法的时间/数组大小图。(数组大小的最差、最佳和平均情况 = 1 000, 10 000,100 000,1 000 000)。我正在使用 DEV C++。但是,当我运行数组大小 = 1 000 000 的代码时,程序崩溃了。这是代码:

#include <stdio.h>

int binarySearch(int arr[], int l, int r, int x)
{
if (r >= l)
{
int mid = l + (r - l)/2;

if (arr[mid] == x) return mid;

if (arr[mid] > x) return binarySearch(arr, l, mid-1, x);

return binarySearch(arr, mid+1, r, x);
}

return -1;
}

int main(void)
{
int arr[10] = {2,5,8,9,15,18,19,25,34,50};
int n = sizeof(arr)/ sizeof(arr[0]);
int x = 10;
int result = binarySearch(arr, 0, n-1, x);
(result == -1)? printf("Element is not present in array")
: printf("Element is present at index %d", result);
return 0;
}

最佳答案

您正在堆栈上分配数组arr。对于 1 000 000 个元素,您需要 4 MB 内存(假设 sizeof(int) == 4)。例如,在 Windows 上,大多数情况下堆栈的默认限制为 1 MB。为了快速修复,将 arr 定义为 static

static int arr[size];

或者放在函数体外部的全局作用域中,或者正如其他人所说,使用动态分配。

关于C 二分和线性搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46631310/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com