合并排序文本文件中的索引超出范围异常 reader
Index out of range exception in Merge Sort Text file reader
我正在尝试使用合并排序对文本文件进行排序。但是,当我尝试 运行 时,我不断收到索引超出范围的异常。我会指定发生异常的区域。
class Program
{
static public void DoMerge(int[] numbers, int left, int mid, int right)
{
int[] temp = new int[25];
int i, left_end, num_elements, tmp_pos;
left_end = (mid - 1);
tmp_pos = left;
num_elements = (right - left + 1);
while ((left <= left_end) && (mid <= right))
{
if (numbers[left] <= numbers[mid])
temp[tmp_pos++] = numbers[left++];
else
temp[tmp_pos++] = numbers[mid++];
}
while (left <= left_end)
temp[tmp_pos++] = numbers[left++];
while (mid <= right)
上面的部分很好,但下面有一个例外。
temp[tmp_pos++] = numbers[mid++];
后面几行没问题。
for (i = 0; i < num_elements; i++)
{
numbers[right] = temp[right];
right--;
}
}
static public void MergeSort_Recursive(int[] numbers, int left, int right)
{
int mid;
if (right > left)
{
mid = (right + left) / 2;
接下来的几行也都给我例外。
MergeSort_Recursive(numbers, left, mid);
MergeSort_Recursive(numbers, (mid + 1), right);
DoMerge(numbers, left, (mid + 1), right);
据我所知,其余的都很好,但我会添加它只是为了让你们看到。
}
}
static void Main(string[] args)
{
string fileNumbers = File.ReadAllText("sort(5).txt");
string[] intNumbers = fileNumbers.Split(new char[] { ' ', '\t', '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries);
int[] numbers = new int[intNumbers.Length];
int len = 999;
//for (int n = 0; n < intNumbers.Length; n++)
//{
// numbers[n] = int.Parse(intNumbers[n]);
//}
Console.WriteLine("MergeSort: ");
MergeSort_Recursive(numbers, 0, len - 1);
for (int i = 0; i < 1; i++)
Console.WriteLine(numbers[i]);
Console.Read();
}
}
我要读取的文本文件有 500 个数字,最大数字为 999,最小数字为 6,数字非常随机,我必须对它们进行排序。
P.S。我知道什么是超出范围的异常,我知道是什么原因导致的,因此我问为什么我的代码会抛出异常。
您的排序代码看起来基本没问题。我 运行 它在一个小数组中并且排序正确。
您的代码中有两个问题导致了 运行ge 异常。
第一个问题是您将 len
设置为 999。
您提到该文件包含 500 个数字,但最好将 len
设置为 numbers.Length
。
static void Main(string[] args)
{
string fileNumbers = File.ReadAllText("sort(5).txt");
string[] intNumbers = fileNumbers.Split(new char[] { ' ', '\t', '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries);
int[] numbers = new int[intNumbers.Length];
int len = numbers.Length;
for (int n = 0; n < intNumbers.Length; n++)
{
numbers[n] = int.Parse(intNumbers[n]);
}
Console.WriteLine("MergeSort: ");
MergeSort_Recursive(numbers, 0, len - 1);
for (int i = 0; i < numbers.Length; i++)
Console.WriteLine(numbers[i]);
//Console.Read(); //Not sure what this is for....
}
第二个问题是当您创建 temp
数组时,您创建的长度为 25。
这将修复该部分:
int[] temp = new int[numbers.Length];
请注意,更好的方法是在主函数中创建 temp
数组,并将其作为参数传递给 MergeSort_Recursive()
和 DoMerge()
,这样您就不会不必在每次合并操作时创建一个新数组。
我正在尝试使用合并排序对文本文件进行排序。但是,当我尝试 运行 时,我不断收到索引超出范围的异常。我会指定发生异常的区域。
class Program
{
static public void DoMerge(int[] numbers, int left, int mid, int right)
{
int[] temp = new int[25];
int i, left_end, num_elements, tmp_pos;
left_end = (mid - 1);
tmp_pos = left;
num_elements = (right - left + 1);
while ((left <= left_end) && (mid <= right))
{
if (numbers[left] <= numbers[mid])
temp[tmp_pos++] = numbers[left++];
else
temp[tmp_pos++] = numbers[mid++];
}
while (left <= left_end)
temp[tmp_pos++] = numbers[left++];
while (mid <= right)
上面的部分很好,但下面有一个例外。
temp[tmp_pos++] = numbers[mid++];
后面几行没问题。
for (i = 0; i < num_elements; i++)
{
numbers[right] = temp[right];
right--;
}
}
static public void MergeSort_Recursive(int[] numbers, int left, int right)
{
int mid;
if (right > left)
{
mid = (right + left) / 2;
接下来的几行也都给我例外。
MergeSort_Recursive(numbers, left, mid);
MergeSort_Recursive(numbers, (mid + 1), right);
DoMerge(numbers, left, (mid + 1), right);
据我所知,其余的都很好,但我会添加它只是为了让你们看到。
}
}
static void Main(string[] args)
{
string fileNumbers = File.ReadAllText("sort(5).txt");
string[] intNumbers = fileNumbers.Split(new char[] { ' ', '\t', '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries);
int[] numbers = new int[intNumbers.Length];
int len = 999;
//for (int n = 0; n < intNumbers.Length; n++)
//{
// numbers[n] = int.Parse(intNumbers[n]);
//}
Console.WriteLine("MergeSort: ");
MergeSort_Recursive(numbers, 0, len - 1);
for (int i = 0; i < 1; i++)
Console.WriteLine(numbers[i]);
Console.Read();
}
}
我要读取的文本文件有 500 个数字,最大数字为 999,最小数字为 6,数字非常随机,我必须对它们进行排序。 P.S。我知道什么是超出范围的异常,我知道是什么原因导致的,因此我问为什么我的代码会抛出异常。
您的排序代码看起来基本没问题。我 运行 它在一个小数组中并且排序正确。
您的代码中有两个问题导致了 运行ge 异常。
第一个问题是您将 len
设置为 999。
您提到该文件包含 500 个数字,但最好将 len
设置为 numbers.Length
。
static void Main(string[] args)
{
string fileNumbers = File.ReadAllText("sort(5).txt");
string[] intNumbers = fileNumbers.Split(new char[] { ' ', '\t', '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries);
int[] numbers = new int[intNumbers.Length];
int len = numbers.Length;
for (int n = 0; n < intNumbers.Length; n++)
{
numbers[n] = int.Parse(intNumbers[n]);
}
Console.WriteLine("MergeSort: ");
MergeSort_Recursive(numbers, 0, len - 1);
for (int i = 0; i < numbers.Length; i++)
Console.WriteLine(numbers[i]);
//Console.Read(); //Not sure what this is for....
}
第二个问题是当您创建 temp
数组时,您创建的长度为 25。
这将修复该部分:
int[] temp = new int[numbers.Length];
请注意,更好的方法是在主函数中创建 temp
数组,并将其作为参数传递给 MergeSort_Recursive()
和 DoMerge()
,这样您就不会不必在每次合并操作时创建一个新数组。