我有以下为自下而上代码归并它确实是对文件的操作间通过-M合并每个双打米通这里是代码自下而上归并
#include <iostream>
#include <vector>
using namespace std;
inline int Min(int a,int b)
{
return a<b?a:b;
}
void merge(int a[],int l,int m,int r)
{
vector<int>b;
int i, j;
for (i=m+1;i>=l;i--) b[i-1]=a[i-1];
for (j=m;j<r;j++) b[r+m-j]=a[j+1];
for (int k=l;k<=r;k++)
if (b[j]<b[i])
a[k]=b[j--];
else
a[k]=b[i++];
}
void mergesort(int a[],int l,int r)
{
for (int m=1;m<=r-l;m=m+m)
for (int i=l;i<=r-m;i+=m+m)
merge(a,i,i+m-1,Min(i+m+m-1,r));
}
int main()
{
int a[]={12,4,7,3,9,8,10,11,6};
int n=sizeof(a)/sizeof(int);
mergesort(a,0,n-1);
for (int i=0;i<n;i++)
{
cout<<a[i]<< " ";
}
return 0;
}
但是当我运行这段代码有例外其中说,向量的超出范围错误发生请帮助
异常来自哪条线?你试图访问什么元素,你相信这个媒介有多大?你那个时候的调用堆栈有多深?索引是否超出范围,i,j或k? 老实说,@ user466441,你的大部分问题都是“这是一堆代码,请帮助”,没有任何信息或你的努力。 – abelenky 2010-11-24 17:23:22
我重新格式化了你的代码。但是,更一致的格式仍然不能解决您的不良变量名称,括号和单行语句的不一致使用。 – abelenky 2010-11-24 17:27:30