您好我想绘制二进制和线性搜索算法的时间/数组大小图。(最差,最佳和平均情况,数组大小= 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;
}
答案 0 :(得分:2)
您正在堆栈上分配数组arr
。对于1 000 000个元素,您需要4 MB的内存(假设sizeof(int) == 4
)。例如,在Windows上,大多数情况下堆栈的默认限制为1 MB。要快速修复,请将arr
定义为static
static int arr[size];
或放在函数体外的全局范围或其他人说,使用动态分配。