如何在合并排序中设置 mid 的值
How do I set value of mid in Merge Sort?
我已经实现了合并排序算法,但它为某些值抛出异常并显示某些值的正确值。例如:如果我的输入数组为:4 3 2 1,那么它会正确显示 1 2 3 4但是,对于输入:1 3 5 2 4 6,它会引发异常。我想这是因为我分配了中。这是我对merge
函数的实现:
void mergeArr(int a[], int l, int mid, int r)
{
int n1, n2;
int i,j,k;
int inv_count = 0;
n1 = mid - l + 1;
n2 = r - mid;
int temp[r-l+1];
int L[n1], R[n2];
for(i = 0;i < n1;i++)
L[i] = a[l+i];
for(j = 0;j < n2;j++)
R[j] = a[mid+j+1];
i = j = 0;
k = l;
while(i<n1 && j<n2)
{
if(L[i] <= R[j])
temp[k++] = L[i++];
else
{
temp[k++] = R[j++];
inv_count += (mid - i);
}
}
while(i<n1)
temp[k++] = L[i++];
while(j<n2)
temp[k++] = R[j++];
for(i=l;i<=r;i++)
a[i] = temp[i];
}
和merge_sort
功能:
void mergeSort(int a[], int l, int r)
{
int inv_count = 0;
if(l < r)
{
int mid;
mid = (l + (r))/2;
mergeSort(a,l,mid);
mergeSort(a,mid+1,r);
mergeArr(a,l,mid, r);
}
//return inv_count;
我发现了问题,将inv_count += (mid - i)
替换为inv_count += (n1 - i)
做了有意义的工作
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 在C++/Linux中设置单调时钟的一些技巧
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 嵌套在类中时无法设置成员数据
- 需要帮助设置在C++中使用的Potrace
- 如何在自删除后将对象设置为nullptr
- 将指针设置为"nullptr"并不能防止双重删除?
- 如何在Ubuntu中使用cmake设置qt4
- ld:bind_at_load和-bitcode_bundle(Xcode设置ENABLE_bitcode=YES)不能
- 如何在boost beast http请求中设置http头
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 如何将这个C++哈希表转换为动态扩展和收缩,而不是使用硬设置的最大值
- 为什么文件名被设置为一个点,而不是在读取矢量中的文件名时
- 如何在24位SDL_Surface上设置像素的颜色
- std::设置自定义比较器
- 如何设置一个范围来提取我想要获得的信息
- 如何在C/C++中用FD_set Unix设置套接字文件描述符
- 通过选项卡的文本设置QTabWidget顺序
- 将特征矩阵的向量设置为0
- 如何在合并排序中设置 mid 的值