1.输入两个整数x1和x2(x1<x2),需要对一个乱序数组排序使得数组左边的元素比x1小,中间的元素介于x1与x2之间,右边的元素比x2大。
例;输入{6,4,10,7,9,2,20,1,3,30} x1=5,x2=8; 输出{3 4 1 2}{6 7}{20 10 9 30}【计学2020】
算法思想:
类似于快速排序的分划分过程
x1为枢轴元素,第一次分划使得左边元素比x1小,右边元素比x1大
x2为枢轴元素,第二次分划使得左边元素比x2小,右边元素比x2大
而此时由于x1<x2,那么恰好左边元素小于x1,中间元素介于x1与x2之间,右边元素大于x2
#include<stdio.h>
void partation(int a[],int left,int right,int x)
//left为数组首元素位置,right为数组首元素位置,x为枢轴元素
{
int i = left;
int j = right;
int tmp = 0;
int key = x;//枢轴元素
while(i < j)
{
while(i<j && a[i]<x)//找比枢轴元素大的元素
{
i++;
}
while(i<j && a[j]>x)找比枢轴元素小的元素
{
j--;
}
//交换
tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
}
int main()
{
int a[10] = {6,4,10,7,9,2,20,1,3,30};
int x1 = 0;
int x2 = 0;
scanf("%d %d",&x1,&x2);
partation(a,0,9,x1);
partation(a,0,9,x2);
for(int i = 0; i < 10; i++)
{
printf("%d ",a[i]);
}
return 0;
}