解题思路:

对于自带排序的语言来说,这道题是很简单的,以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.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论