本文主要是介绍已知数组A[1..n]中元素类型为非负整数,设计算法将其调整为左右两部分,左边所有为奇数,右边所有为偶数,并要求算法的时间复杂度为O(n),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
//左边奇数右边偶数
void Swap(int* a, int* b) {int tmp = *b;*b = *a;*a = tmp;
}
void LeftRight(int arr[],int n) {int i = 0;int j = n - 1;while(i<j){if (arr[i] % 2 == 0 && arr[j] % 2 == 1) {Swap(&arr[i], &arr[j]);i++;j--;}else if (arr[i] % 2 == 1 && arr[j]%2== 1) {i++;}else if (arr[i] % 2 == 0 && arr[j]%2== 0) {j--;}else if (arr[i] % 2 == 1 && arr[j]%2== 0) {i++;j--;}}
}
int main()
{int arr[20] = { 0 };//默认最大输入长度不超过20int n = 0;printf("请输入数组长度n:");scanf("%d", &n);int i = 0;printf("\n请输入数组数据:");for (i = 0;i < n;i++){scanf("%d", &arr[i]);}printf("\n调整后的数组为:");LeftRight(arr, n);for (i = 0;i < n;i++){printf("%d ", arr[i]);}
}
这篇关于已知数组A[1..n]中元素类型为非负整数,设计算法将其调整为左右两部分,左边所有为奇数,右边所有为偶数,并要求算法的时间复杂度为O(n)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!