我有以下爲自下而上代碼歸併它確實是對文件的操作間通過-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