c语言实现奇偶排序算法
=====
第2题:奇偶排序(一)
=====
总时间限制:
1000ms
内存限制:
65536kB
描述
输入十个整数,将十个整数按升序排列输出,并且奇数在前,偶数在后。
输入
输入十个整数
输出
按照奇偶排序好的十个整数
#include<stdio.h>#define COUNT 10
#define bool int
#define true 1
#define false 0
/****
*负责冒泡排序
***/
int* sortFunction(int data[]){
int i,j;
for(j=0;j<COUNT-1;j++){
for(i=0;i<COUNT-1-j;i++){if (data[i]>data[i+1]){
int tmp=data[i]; data[i]=data[i+1];data[i+1]=tmp;
}}
}
return data;
}/****
**负责判断奇数或者偶数
*/
bool isOddNumber(int data){if(data % 2==0){
return false;
}else{
return true;
}
}main()
{
int arr[]={10, 9 ,8, 7 ,6, 5, 4, 3, 2, 1};
int oddArr[COUNT]={0},evenArr[COUNT]={0};
int *tmp=NULL;
int i;
int m=0;
int n=0;
for(i=0;i<COUNT;i++){
if(isOddNumber(arr[i])){
evenArr[m++]=arr[i];
}else{
oddArr[n++]=arr[i];
}
}//对于奇数数组排序
tmp=sortFunction(oddArr);
puts("\n========odd number==========\n");
for(i=0;i<COUNT;i++){
int num=*tmp;
if(num!=0)
{
printf("%d ",num);
}
*tmp++;
}
//对于偶数数组排序
tmp=sortFunction(evenArr);
puts("\n========even number==========\n");
for(i=0;i<COUNT;i++){
int num=*tmp;
if(num!=0)
{
printf("%d ",num);
}
*tmp++;
}printf("over");
}
以上代码编写与vs2012里完成。
您可能感兴趣的文章:
- c语言之消除注释函数的实现——我读《c程序设计语言》
- C语言通用数据类型链表的实现,(数据域为指针,可指向任意类型数据)
- C语言实现由PID获取进程名&由进程名获取PID
- 基于C语言实现三子棋
- 【c语言】模拟实现库函数的atof函数
- LeetCode-54-Spiral Matrix(C语言实现)
- 编辑距离问题c语言实现
- HOG特征提取代码(opencv处理基本数据,c语言实现基本算法)
- 链表的C语言实现之循环链表及双向链表
- C语言实现链式队列
- 简单层次状态机的C语言实现
- 在微机中或者C语言中指针的功能是如何实现的?
- C语言实现bmp图像的平移操作
- 使用C语言实现pcm格式音频文件播放速度的改变
- C语言获取Shell返回结果的实现方法
- c语言实现的内存池
- C语言字符串库函数的实现
- URL encode 与 URL decode 的C语言实现
- 算法导论(Introduction to Algorithms)之堆排序(C语言实现)
- C语言实现简易版三子棋