0

我的合并排序实现仅部分工作,有时甚至会引发段错误。

输入:5 4 3 2 1 输出:0 1 2 3 4

输入:7 6 5 4 3 2 1 输出:0 1 2 3 4 5 6

输入:4 3 2 1 输出:[一些垃圾值] 1 2 3

输入:1 2 3 4 5 67 7 8 输出:[一些垃圾值] 1 2 3 4 5 7 8

似乎奇数输入不会导致段错误,但偶数输入会。尽管如此,在这两种情况下,最大值都没有出现在输出中。任何帮助,将不胜感激。

void merge(vector<int>& a, int i, int j)
{
     int b[a.size()];
     int start = i;
     int mid = (i+j)/2;
     int k = mid+1;
     int l = i;
     while(i<=mid && k<=j)
     {
       if(a[i] >= a[k])
         b[l++] = a[k++];
       else
         b[l++] = a[i++];
     }

     if(i>mid)
     {
      while(k<=j)
        b[l++] = a[k++];
     }
     else
     {
      while(i<=mid)
        b[l++] = a[i++];
     }

     for(l=start; l<=j; l++)
       a[l] = b[l];
 }

void merge_sort(vector<int>& a, int l, int u)
{
     int m;
     if(l < u)
     {
          m = (l+u)/2;
          merge_sort(a,l,m);
          merge_sort(a,m+1,u);
          merge(a,l,u);
      }
 }

 //relevant portion in main
   cin >> n;
   cout << "n: " << n << endl;
   a.resize(n);
   for(int j=0; j<n; j++)
     cin >> a[j];

   cout << endl;
   merge_sort(a, 0, a.size());
4

1 回答 1

0

你不应该达到j(" ...<= j...") when jcould be a.size()。试试a.size() - 1

于 2013-09-24T12:34:44.980 回答