代码拉取完成,页面将自动刷新
#include<stdio.h>
#include<stdlib.h>
void guibingpaixu(int *p, int *q, int left, int right);
void guibingcaozuo(int *p, int *q, int left, int right);
int main(){
int n;
scanf("%d", &n);
int *p = NULL, *q = NULL;
p = (int*)malloc(sizeof(int) * n);
q = (int*)malloc(sizeof(int) * n);
for(int i = 0;i < n;i ++){
scanf("%d", &p[i]);
}
guibingpaixu(p, q, 0, n - 1);
for(int i = 0;i < n;i ++){
printf("%d ", p[i]);
}
printf("\n");
return 0;
}
void guibingpaixu(int *p, int *q, int left, int right){
if(left < right){
int middle = (left + right) / 2;
guibingpaixu(p, q, middle + 1, right);
guibingpaixu(p, q, left, middle);
guibingcaozuo(p, q, left, right);
}
}
void guibingcaozuo(int *p, int *q, int left, int right){
int middle = (left + right) / 2;
int mid = middle + 1;
int i = left;
int j = mid;
int k = left;
while(i < mid && j <= right){
if(p[i] < p[j]){
q[k] = p[i];
i ++;
k ++;
}
else if(p[i] > p[j]){
q[k] = p[j];
j ++;
k ++;
}
}
while(i < mid){
q[k] = p[i];
i ++;
k ++;
}
while(j <= right){
q[k] = p[j];
j ++;
k ++;
}
for(int m = left;m <= right;m ++){
p[m] = q[m];
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。