一个未排序整数数组,有正负数,重新排列使负数排在正数前面,并且要求不改变原来的正负数之间相对顺序,比如: input: 1,7,-5,9,-12,15 ans: -5,-12,1,7,9,15 要求时

#include <iostream>
using namespace std;

void txsort(int* arr, int len) {
	if (!arr || len == 1) {
		return;
	}
	int negCount = 0;
	for (int i = 0; i < len; ++i) {
		if (arr[i] < 0) {
			negCount++;
		}
	}

	int swapingId = 0;
	int fixNegId = 0;
	int toSwapId = 0;
	for (int i = 0; i < len; ++i) {
		swapingId = (i - fixNegId) % (negCount - fixNegId) + fixNegId;
		toSwapId = i + negCount - fixNegId;

		/*arr[swapingId] < 0说明此处的负数未固定,
		 *  将带交换元素下标定位至待固定元素下标
		 */
		if (arr[swapingId] < 0) {
			toSwapId = fixNegId;
			fixNegId++;
		}

		swap(arr[swapingId], arr[toSwapId]);

		if (fixNegId == negCount) {
			break;
		}
	}
}
上一篇:【c语言】输入一个递增排序的数组的一个旋转,输出旋转数组中的最小元素


下一篇:剑指Offer面试题:7.旋转数组的最小数字