排序(真题)

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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值