数组中的反转次数不正确
本文关键字:不正确 数组 | 更新日期: 2023-09-27 17:49:56
你能帮我在 C# 上的代码中找到一个错误来计算数组中的反转吗?计数不正确。例如,在数组 {3, 8, 6, 1} 中,它应该是 4,但它是 3。但是,它适用于数组 {4, 3, 2, 1} 并显示 6。程序读取的文本文件 (1111.txt ( 中的每个字符串都包含 1 个数组元素。谢谢。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.IO;
namespace C
{
class Program
{
public static long k1 = 0;
static long Marge_sort(int[] A, int p, int r)
{
int q = p;
if (r <= p) return 0;
q = (p + r) / 2;
C.Program.k1 = Marge_sort(A, p, q);
C.Program.k1 += Marge_sort(A, q + 1, r);
C.Program.k1 += Marge(A, p, q, r);
return C.Program.k1;
}
static long Marge(int[] A, int p, int q, int r)
{
long k1 = 0;
int n1 = q - p+1 ;
int[] L = new int[n1+1];
int n2 = r - q;
int i;
int[] R = new int[n2+1];
for(i=0;i<n1;i++)
{
L[i] = 0;
L[i] = A[p + i ];
}
L[n1] = int.MaxValue;
for (i = 0; i < n2; i++)
{
R[i] = 0;
R[i] = A[q + i+1];
}
R[n2] = int.MaxValue;
int j = 0; i = 0;
for(int k=p;k<=r;k++)
{
if (L[i] <= R[j])
{
A[k] = L[i];
i++;
}
else
{
A[k] = R[j];
j++;
k1 = q - i+1 ;
}
}
return k1;
}
static void Main(string[] args)
{
long k1 = 0;
int leght = 0, el = 0;
int[] Ch = new int[leght];
StreamReader s = File.OpenText(@"D:'1111.txt");//IntegerArray
string read = null;
while ((read = s.ReadLine()) != null)
{
//Console.WriteLine(read);
leght++;
Array.Resize(ref Ch, leght);
Ch[el] = Convert.ToInt32(read);
el++;
}
s.Close();
k1=Marge_sort(Ch, 0, leght-1 );
Console.WriteLine("'n"+k1.ToString());
Console.ReadLine();
}
}
}
接近Marge
末尾的行
k1 = q - i+1 ;
应该是
k1 += n1 - i;
首先,您保持一个L
元素的运行总数 R
必须在前面移动。因此,操作员应+=
而不是=
。
其次,q
测量原始数组A
中的位置。您正在计算小数组L
中的许多元素,因此您应该从该数组的大小(不包括保护值(中减去该数组的大小n1
索引。如果A
很大,你会开始看到疯狂的结果:当你合并只有几个元素但非常接近A
顶部的小子数组时,你会看到巨大的q
值,这与L
的大小无关。
当你确保你的代码正常工作时,你应该转到 codereview.stackexchange.com。它们只有助于工作代码,但它们会给你很多关于如何以更干净、更易读的方式编写东西的指示。您的代码充满了小错误,例如不必要的命名空间、未使用的初始化等(但我认为在担心这些错误之前让它正常工作是正确的方法(。
对于数组 {3, 6, 8, 1},正确答案是 3:
{3