调整数组使奇数全部都位于偶数前面

#include<stdio.h>

void sort(int *p, int len)
{
	int *end = p;
	end = p + len - 1;
	while (p<end)
	{
		if (*p % 2 == 0)
		{
			while (end)
			{
				if (*end % 2 == 1)
				{
					break;
				}
				end--;
			}
			int tmp = *end;
			*end = *p;
			*p = tmp;
			p++;
		}
		else
		{
			p++;
		}

	}

}
int main()
{
	int arr[] = { 3,5,4,8,9,5,6,2,6};
	int len = sizeof(arr) / sizeof(arr[0]);
	sort(arr,len);
	int i = 0;
	for (i = 0; i < len; i++)
	{
		printf("%d", arr[i]);
	}

	return 0;
}

输出结果为3,5,5,9,8,4,6,2,6
这道题我的的想法是定上两个标志,一个指向首部一个指向尾部,判断首元素如果是奇数则不管他,如果是偶数则和最后一个比较,这是如果尾部元素是奇数则交换否则尾部元素向前移动,直到找到奇数,依次循环,直到两个标志相遇停下。
时间: 2024-10-25 03:23:31

调整数组使奇数全部都位于偶数前面的相关文章

【C语言】调整数组使奇数所有都位于偶数前面

//调整数组使奇数全部都位于偶数前面. //输入一个整数数组.实现一个函数.来调整该数组中数字的顺序使得数组中全部的奇数位于数组的前半部分,全部偶数位于数组的后半部分 #include <stdio.h> void Adjust(int arr[],int len) { int i, j; for (i = 0; i < len; i++) { if ((arr[i]%2)==0) for (j = i + 1; j < len; j++) { int temp; if ((arr

【c语言】调整数组使奇数全部都位于偶数前面

// 调整数组使奇数全部都位于偶数前面 // 输入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分, // 所有偶数位于数组的后半部分. #include <stdio.h> #include <assert.h> void johh(int *p, int len) { int *q = p + len - 1; int temp; assert(p != NULL); while (p < q) { while ((*p &

写一函数,调整数组使奇数全部都位于偶数前面

调整数组使奇数全部都位于偶数前面.  输入一个整数数组,实现一个函数,  来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分, 所有偶数位于数组的后半部分. 1 #include<stdio.h> 2 3 #define NUM 10 4 5 void Change_num(int* start, int* end) 6 { 7 //开头找偶数,结尾找奇数,找到后两个相互交换位置 8 //1,2,3,4,5,6,7,8,9,5 9 //1, 3, 5, 4, 5, 6, 7, 8,

C语言编程 调整数组使奇数全部都位于偶数前面

题目:输入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分. 主要思想:遍历这个数列,若遍历到的数字为奇数,则再次遍历数列找到第一个偶数与其交换位置. 源代码: #include<stdio.h> #include<stdlib.h> void Exchange(int array[],int length) { int i,m,temp; for (i = 0; i < length; i++) { if

调整数组使奇数全部都位于偶数前面。

#include<stdio.h> #include<assert.h> void ReorderOddEven(int arry[], int size) { assert(arry); if (arry == NULL || size <= 0) { return; } int begin = 0; int temp = 0; int end = size - 1; while (begin<end) { while (begin<end &&

C语言:调整数组使奇数全部都位于偶数前面。

#define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> #include<stdlib.h> #include<assert.h> void even_old_number(int *arr, int len) {      assert(arr);      int i = 0;      int j = 0;      int tmp = 0;      for (i = 0; i < len; i++)    

剑指Offer之调整数组使奇数位于偶数前面(题14)

1 /****************************************                                                                                                    2     > File Name:test.c   3     > Author:xiaoxiaohui   4     > mail:[email protected]   5     > Cre

调整数组使奇数位于偶数前面

如果考虑暴力解决的话,就每次从前往后扫面,遇到偶数就放在最后,这样时间复杂度就是O(n*n),对于这种问题明显过高了,我们考虑扫描一遍,用两个指针,一个从前往后,另一个从后往前,碰到前偶后奇的时候就交换,这样算法复杂度只有O(n). #include<stdio.h> #include<stdlib.h> void reset(int a[],int n) { int i=0,j=n-1,tmp=0; while(i<j) { if((a[i]%2==1)&&

将数组的奇数放在左边,偶数放在右边

/** * 使用两个指针i和j,初始化均为0.然后j往后遍历,若遇到了奇数,则将 A[j] 和 A[i] 交换位置,同时i自增1,这样操作下来,同样可以将所有的偶数都放在奇数前面 * */ public class SortArrayByParity { public static void main(String[] args) { int [] arr = new int[] {2,3,4,5,6,7,8,9,10,12,14,15,16,17}; sort(arr); Arrays.str