编程算法 - 将排序数组按绝对值大小排序 代码(C)

将排序数组按绝对值大小排序 代码(C)


本文地址: http://blog.csdn.net/caroline_wendy


排序的数组有可能包含正负, 可以使用折半查找确定中值位置, 然后再使用两个指针, 顺次排序两端.

解决思路是:

    1.数组中的元素全为正,返回;

    2.数组中的元素全为负,返回;

    3.数组中有正数有负数,就用二分法查找,判断中间元素的符号

       a)中间元素为正,继续判断中间元素前面一个元素的符号;

       b)中间元素为负,判断中间元素后一个元素的符号;

       c)中间元素为零,令其等于结果值返回;


时间复杂度O(nlogn)

代码:

/*
 * main.cpp
 *
 *  Created on: 2014.9.12
 *      Author: Spike
 */

/*eclipse cdt, gcc 4.8.1*/


#include <stdio.h>
#include <stdlib.h>

using namespace std;

void Reverse(int* begin, int* end) {
	while (begin < end) {
		int tmp = *begin;
		*begin++ = *end;
		*end-- = tmp;
	}
}

void AbsoluteSort(int res[], int data[], const int length) {
	if (data == NULL || length <= 0) {
		res = data;
		return;
	}
	if ((data[0]<0 && data[length-1]<0) || (data[0]>0 && data[length-1]>0)) {
		res = data;
		return;
	}
	int left = 0;
	int right = length-1;
	int mid;
	while (left < right) {
		mid = left + ((right-left)>>1);
		if (data[mid]>0 && data[mid-1]<=0) {
			right = mid; left = mid-1;
			break;
		} else if (data[mid]>0) {
			right = mid;
		} else if (data[mid]<0 && data[mid+1]>=0) {
			left = mid; right = mid+1;
			break;
		} else if (data[mid]<0) {
			left = mid;
		} else {
			break;
		}
	}

	int num=0;
	while (right < length && left >=0) {
		if (abs(data[right]) <= abs(data[left])) {
			res[num++] = data[right++];
		} else {
			res[num++] = data[left--];
		}
	}
	while (right < length)
		res[num++] = data[right++];
	while (left >=0 ) {
		res[num++] = data[left--];
	}

}

int main (void) {
	int data[] = {-5, -4, -2, -1, 0, 1, 2, 6};
	const int length = sizeof(data)/sizeof(data[0]);
	int res[length];
	AbsoluteSort(res, data, length);
	for (int i=0; i<length; ++i) {
		printf("%d ", res[i]);
	}
	printf("\n");
}


输出:

0 1 -1 2 -2 -4 -5 6 





  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SpikeKing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值