合并排序(归并)

//mergeSort.h

#include <vector>
using std::vector;

class MergeSort
{
public:
 MergeSort(int);
 void sort();
 void displayElements()const;
private:
 int size;
 vector<int>data;
 void sortSubVector(int,int);
 void merge(int,int,int,int);
 void displaySubVector(int,int) const;
};

//mergeSort.cpp

#include "stdafx.h"
#include <iostream>
using std::cout;
using std::endl;

#include <vector>
using std::vector;

#include <cstdlib>
using std::rand;
using std::srand;

#include <ctime>
using std::time;

#include "MergeSort.h"

MergeSort::MergeSort(int vectorSize)
{
 size = (vectorSize>0? vectorSize:10);
 srand(time(0));
 for (int i = 0;i<size;i++)
 {
  data.push_back(10 + rand() %90);
 }
}

void MergeSort::sort()
{
 sortSubVector(0,size - 1);
}

void MergeSort::sortSubVector(int low, int high)
{
 if ((high - low)>=1)
 {
  int middle1 = (low + high)/2;
  int middle2 = middle1 + 1;
/*  cout<<"split:    ";
  displaySubVector(low,high);
  cout<<endl<<"        ";
  displaySubVector(low,middle1);
  cout<<endl<<"        ";
  displaySubVector(middle2,high);
  cout<<endl<<"        ";
*/
  sortSubVector(low,middle1);
  sortSubVector(middle2,high);
  
  merge(low,middle1,middle2,high);
 }
}

void MergeSort::merge(int left,int middle1,int middle2,int right)
{
 int leftIndex = left;
 int rightIndex = middle2;
 int combinedIndex = left;
 vector<int> combined(size);

/* cout<<"merge:     ";
 displaySubVector(left,middle1);
 cout<<endl<<"        ";
 displaySubVector(middle2,right);
 cout<<endl;
*/
 while (leftIndex <= middle1 && rightIndex <=right)
 {
  if (data[leftIndex] <= data[rightIndex])
  {
   combined[combinedIndex++] = data[leftIndex++];
  }
  else
   combined[combinedIndex++] = data[rightIndex++];
 }
 if (leftIndex ==middle2)
 {
  while (rightIndex<=right)
  {
   combined[combinedIndex++] = data[rightIndex++];
  }
 }
 else
 {
  while (leftIndex<= middle1)
  {
   combined[combinedIndex++] = data[leftIndex++];
  }
 }
 for (int i = left;i<=right;i++)
 {
  data[i] = combined[i];
 }
/* cout<<"        ";
 displaySubVector(left,right);
 cout<<endl<<endl;
*/
}

void  MergeSort::displaySubVector(int low,int high) const
{
 for (int i = 0;i< low;i++)
 {
  cout<<"     ";
 }
 for (int i = low;i<=high;i++)
 {
  cout<<"    "<<data[i];
 }
}
void MergeSort::displayElements()const
{
 displaySubVector(0,size - 1);
}

 

//测试文件/

#include "mergeSort.h
int _tmain(int argc, _TCHAR* argv[])
{
 MergeSort sortVector(10);
 cout<<"unsorted vector:"<<endl;
sortVector.displayElements();

 cout<<endl<<endl;

 sortVector.sort();
 cout<<"sorted vector:"<<endl;

sortVector.displayElements();
 cout<<endl;

 return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值