请问一下这个题怎么做?
对于整数有不同的分类方法,可以按正负数划分,也可以按奇偶数划分等。现在要对一批整数做-个基本划分,方法是分别按奇数和偶数分组。请你编写一个程序,首先输入正整数N,然后输入N个整数,而输出则是对输入的N个整数按输入顺序先输出所有奇数,而后再输出偶数。
[输入]
两行,第一行为一个整数N (N>0),第二行为N个整数,两个整数之间用一一个空格分隔。
[输出]
N个整数,每个数前面一个空格。
[样例输入]
18 37 21 6 20 15
[样例输出]
37 21 15 18 6 20
C语言程序设计数组问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- threenewbee 2020-04-19 18:06关注
如果问题得到解决的话,请点下采纳
#include <stdlib.h> #include <stdio.h> int * order; int * p; int cmp(const void * a, const void * b) { int x = *(int *)a; int y = *(int *)b; if (p[x] % 2 == p[y] % 2) return x - y; return p[y] % 2 - p[x] % 2; } int main() { int n; scanf("%d", &n); p = (int *)malloc(sizeof(int) * n); order = (int *)malloc(sizeof(int) * n); for (int i = 0; i < n; i++) { scanf("%d", &p[i]); order[i] = i; } qsort(order, n, sizeof(int), cmp); for (int i = 0; i < n; i++) printf("%d ", p[order[i]]); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 为什么nacos注册失败了呀?
- ¥15 为什么在配置Linux系统的时候执行脚本总是出现E: Failed to fetch http:L/cn.archive.ubuntu.com
- ¥15 Cloudreve保存用户组存储空间大小时报错
- ¥15 伪标签为什么不能作为弱监督语义分割的结果?
- ¥15 编一个判断一个区间范围内的数字的个位数的立方和是否等于其本身的程序在输入第1组数据后卡住了(语言-c语言)
- ¥15 游戏盾如何溯源服务器真实ip?
- ¥15 Mac版Fiddler Everywhere4.0.1提示强制更新
- ¥15 android 集成sentry上报时报错。
- ¥50 win10链接MySQL
- ¥15 抖音看过的视频,缓存在哪个文件