请问我的归并排序哪里出错了 求指导

kkatnk 2012-10-17 07:04:46
#include<iostream>

using namespace std;




int mergesort(int a[],int b[],int mm, int nn);


int merge(int low,int midd,int high,int pre[],int pro[]);




int mergesort(int a[],int b[],int mm,int nn) {

int mid;

if(mm<nn){

mid = mm+nn/2;

mergesort(a ,b,mm,mid);

mergesort(a,b,mid+1,nn);

merge(mm,mid,nn,a,b);

}
return 0;
}


int merge(int low,int midd,int high,int pre[],int pro[]){

int a=low,b=midd+1,c=low;


while(a<=midd&&b<=high)

{
if(pre[a]<pre[b]){

pro[c++]=pre[a++];

}

else

pro[c++]=pre[b++];
}

while(a<=midd){

pro[c++]=pre[a++];
}

while(b<=high){

pro[c++]=pre[b++];
}


for(int tt=low;tt<=high;tt++){

pre[tt]=pro[tt];

}


return 0;
}






//主函数
int main(){

int m,n;

cin>>n;
int i[n],j[n];



for(m=0;m<n;m++){

cin>>i[m];

}


mergesort(i,j,0,n-1);


for(int mm=0;mm<10;mm++){


cout<<i[mm];

}

return 0;

}
...全文
57 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
newtee 2012-10-17
  • 打赏
  • 举报
回复
见另一个帖子
dpdp_2012 2012-10-17
  • 打赏
  • 举报
回复
mid = mm+nn/2; --> mid = (mm+nn)/2;
而且int i[n],j[n];这样定义应该不行

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧