|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
#include<stdio.h>
#define MAX 10000
struct List
{
int data[MAX];
int length;
};
List list;
void init(List &list,int n);
void MergeSort(List &list);
void Sort(List &list,int L,int mid,int R);
void init(List &list,int n)
{
int i;
list.length=0;
printf("输入序列:");
for(i=0;i<n;i++)
{
scanf("%d",list.data[i]);
list.length++;
}
}
void MergeSort(List &list,int L,int R)
{
if(L>=R){
return ;
}
int mid=(L+R)/2;
MergeSort(list,L,mid); //左侧分治
MergeSort(list,mid+1,R); //右侧分治
Sort(list,L,mid,R); //排序
}
void Sort(List &list,int L,int mid,int R)
{
int a[list.length];
int i=L;
int k=0;
int j=mid+1;
while(i<=mid&&j<=R)
{
if(list.data[i]<list.data[j]){
a[k++]=list.data[i++];
}
else{
a[k++]=list.data[j++];
}
}
if(i==mid+1)
{
while(j<=R)
{
a[k++]=list.data[j++];
}
}
if(j==R+1)
{
while(i<=mid)
{
a[k++]=list.data[i++];
}
}
for(i=L,j=0;j<k;i++,j++)
{
list.data[i]=a[j];
}
}
int main(void)
{
int n;
int i;
printf("输入整数个数:");
scanf("%d",&n);
init(list,n);
MergeSort(list,0,list.length);
printf("输出排序结果:");
for(i=0;i<n;i++)
{
printf("%d ",list.data[i]);
}
printf("\n");
return 0;
}
本帖最后由 xieglt 于 2020-9-16 16:57 编辑
代码里有2个错误,
1、函数 void init(List &list,int n) 里头 scanf("%d",list.data[i]); 应该写成
scanf("%d",&list.data[i]);
2、void Sort(List &list,int L,int mid,int R) 里头 int a[list.length]; 应该写成
int * a = (int *)malloc(list.length);
后面记得 free(a);
记得包含头文件 #include "stdlib.h"
|
|