所以我在代码开头遇到了分段错误。我尝试在不同的点运行一些测试,错误似乎是当我为数组分配内存时。我刚刚开始学习堆和堆栈内存,所以我不确定我是否在那里做错了什么。任何帮助将不胜感激。
#include <iostream>
using namespace std;
//Function Prototypes
void sort(int A[], int n);
int findMin(int A[], int n, int j);
int swap(int& a, int& b);
double median(int A[], int n);
void output1(int median);
void output2(double median);
int main()
{
int size;
int array[size]; //Segmentaion fault here
int i = 0;
cout << "Enter the size of the list (< 1 to quit): ";
cin >> size;
while(size >= 1)
{
double element;
cout << "Enter element " << i+1 << ": ";
cin >> element;
array[i] = element;
i++;
while(i < size)
{
cout << "Enter element " << i+1 << ": ";
cin >> element;
array[i] = element;
i++;
}
sort(array, size);
median(array, size);
cout << "Enter the size of the list (< 1 to quit): ";
cin >> size;
}
delete [] array;
return 0;
}
void sort(int A[], int n)
{
int min;
for(int i = 0; i < n; i++)
{
min = findMin(A,n,i);
//min = findMinIndex(p, size, i);
//if(min )
swap(A[i],A[min]);
//swap(p[i],p[min]);
}
}
int findMin(int A[], int n, int j)
{
int minIndex = j;
for(int i = j+1; i < n; i++)
if(A[i]<A[minIndex])
minIndex = i;
return minIndex;
}
int swap(int& a, int& b)
{
int temp;
temp = a;
a = b;
b = temp;
}
void output1(int median)
{
cout << "The median is " << median << "." << endl;
}
void output2(double median)
{
cout << "The median is " << median << "." << endl;
}
double median(int A[], int n)
{
if(n % 2 == 0)
{
int div1 = n / 2;
int num1 = A[div1];
int num2 = A[div1 -1];
double median = (num1 + num2) / 2;
output2(median);
}
else
{
int div2 = n - 1;
int median = div2 / 2;
output1(median);
}
}
因为你没有初始化size
,所以该变量中的值可以是任何东西。 如果它碰巧太大,比如 106,840,406,那么您将无法获得该大小的int[]
。
所以基本上,将你的size
变量初始化为合理的变量。
错误 11 等于说"索引超出范围"...
Index
0, 1, 2, 3, 4 ,5
值 5, 6 ,1 ,9 ,8 ,7
数组长度为 6,但它的最后一个索引是 5.. 例如,如果我们用 6 控制一个 for 循环,那么我们得到分段错误 11...
c++ 中的数组必须以固定大小初始化。在您的情况下,size 不会初始化为任何固定整数值,这在 c++ 中是非法的,并且会导致编译器生成错误消息。
如果在初始化大小数组之前尝试以下行,则可以判断最初的大小:
cout << size << endl;
我用这一行编译了你的代码,并在编译器失败之前得到了这个 int 大小:
1995231824(每个编译器和计算机都不同,但每个数字都会像这个一样大而无用)
试图拥有如此大的数组自然会导致分段错误。这就是为什么您必须将变量大小初始化为固定数字的原因。这将消除分段错误。