【C语言】【面试题】【笔试题】调整数组使奇数全部都位于偶数前面

原创 2016年05月30日 15:02:59
                    void swap(int *a, int *b)
{
     int tmp = *a;
     *a = *b;
     *b = tmp;
}
void print(int arr[], int size)
{
    int i = 0;
    for (; i < size; i++)
    {    
         printf("%d ", arr[i]); 
    }
}

int main()
{

     int arr[] = { 1, 2, 5, 4, 3, 6 };
     int size = sizeof(arr) / sizeof(arr[0]);
     int i = 0, j = 0;
     while (1)
    {
         for (i = 0; i < size; i++)
        {
            if (arr[i] % 2 == 0)
            {
                break;     
             }
        }
        j = i + 1;
        for (; j < size; j++)
        {
            if (arr[j] % 2 == 1)
            {
                break;
            }
        }

      if (j < size)
       {
            swap(&arr[i], &arr[j]);
        }
      else
        {
            break;
         }
}
    print(arr, size);
    system("pause");
    return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

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

//调整数组使奇数全部都位于偶数前面。 //输入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分 #include void A...
  • doudouwa1234
  • doudouwa1234
  • 2015年07月07日 15:14
  • 919

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

// 调整数组使奇数全部都位于偶数前面 // 输入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分, // 所有偶数位于数组的后半部分。 #inclu...
  • zhaoyaqian552
  • zhaoyaqian552
  • 2015年07月08日 09:30
  • 898

牛客网刷题之调整数组顺序使奇数位于偶数前面

题目描述:解题思路:  如果是强解的话,就可以从头扫描这个数组,每碰到一个偶数时,拿出这个数字,并把位于这个数字后面的所有数字都往前挪动一位,这种解法显然是O(n^2)的,不用想都知道,这不可能通过测...
  • lks1139230294
  • lks1139230294
  • 2016年10月08日 23:01
  • 671

剑指offer 面试题14:调整数组顺序使奇数位于偶数前面(C++版)

题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分。 思路分析: 可以维护两个指针i和j,i指向数组的第一个数字,它只向后移...
  • Mary19920410
  • Mary19920410
  • 2017年04月12日 10:55
  • 243

调整数组顺序使奇数位于偶数前面(java)

一、问题描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 二、算法...
  • tanjie_123
  • tanjie_123
  • 2016年11月06日 18:52
  • 930

JAVA实现调整数组顺序使奇数位于偶数前面问题(《剑指 offer》)

题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 pu...
  • qq_15062527
  • qq_15062527
  • 2015年10月02日 15:57
  • 1094

调整数组顺序使奇数位于偶数前面[

题目:输入一个整数数组,调整数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。要求时间复杂度为O(n)。 方法:设2个头尾指针begin和end, begin...
  • fanzitao
  • fanzitao
  • 2012年08月24日 09:03
  • 2869

将无序数组中的奇数放在偶数前面

package test; import java.util.Arrays; public class Test2 { //类似快速排序 static void change(int[] a...
  • kangaroo835127729
  • kangaroo835127729
  • 2015年03月10日 20:51
  • 693

经典算法——调整数组顺序使奇数位于偶数前面

一、题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 ...
  • geekmanong
  • geekmanong
  • 2016年03月19日 15:42
  • 1373

剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面

题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。 1、基本实现: 如果不考虑时间复杂度,最简单的思路应该是从头扫描这个数组,...
  • jsqfengbao
  • jsqfengbao
  • 2015年08月01日 12:41
  • 3551
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【C语言】【面试题】【笔试题】调整数组使奇数全部都位于偶数前面
举报原因:
原因补充:

(最多只允许输入30个字)