原题链接:整数奇偶排序
解题思路:
对于自带排序的语言来说,这道题是很简单的,以c++的sort为例,cmp返回真,ab的位置保持不变,cmp返回假,ab调换顺序。
也就是说我们需要实现三个功能,1.所有的奇数在偶数前面 2.奇数从大到小排序 3.偶数从小到大排序
如果ab都是奇数的话使用return a>b实现从大到小,如果ab都是偶数return a<b实现从小到大,除此之外就是将奇数放在偶数的前边。
使用return a&1 1.a是奇数,返回1,a在前边保持不变 2.a是偶数,返回0,将a换到后边。
以上三种需求可以使用return (a&1?a:-a)>(b&1?b:-b);一条语句实现,大家可以感受一下。
还有就是输入的数量不定,所以使用了一个循环,用了一个小技巧。
参考代码:
#include <iostream> #include <algorithm> #define ll long long using namespace std; int cmp(int a,int b){ return (a&1?a:-a)>(b&1?b:-b); } int main() { ll i,n=10; ll p[n]; while(cin>>p[0]){ for(i=1;i<n;i++)cin>>p[i]; sort(p,p+n,cmp); for(i=0;i<n;i++)cout<<p[i]<<" "; cout<<endl; } return 0; }
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复