输入n个数进行排序,要求先按奇偶后按从小到大的顺序排序

文章目录


一、题目描述

cpp 复制代码
题目描述
Time Limit: 1000 ms
Memory Limit: 256 mb
输入n个数进行排序,要求先按奇偶后按从小到大的顺序排序。

输入输出格式
输入描述:
第一行输入一个整数n,表示总共有多少个数,n<=1000。
第二行输入n个整数,用空格隔开。
输出描述:
输出排序之后的结果。
输入输出样例
输入样例#:
8
1 2 3 4 5 6 7 8
输出样例#:
1 3 5 7 2 4 6 8

二、参考代码

cpp 复制代码
#include <iostream>
#include <string>
#include <algorithm>
#include <math.h>
using namespace std;

int main()
{
	int n;
	cin >> n;
	int* arr = new int[n+1];
	for (int i = 0; i < n; i++)
	{
		cin >> arr[i];
	}
	sort(arr,arr + n);

	int *arr1 = new int[n + 1];
	int* arr2 = new int[n + 1];
	int count1 = 0;
	int count2 = 0;
	for (int i = 0; i < n; i++)
	{
		if (arr[i] % 2 == 0)
		{
			arr2[count2] = arr[i];
			count2++;
		}
		else
		{
			arr1[count1] = arr[i];
			count1++;
		}
	}
	for (int i = 0; i < count1; i++)
	{
		cout << arr1[i] << " ";
	}
	for (int i = 0; i < count2; i++)
	{
		cout << arr2[i]<<" ";
	}

	return 0;
}

相关推荐
2501_9403152612 小时前
leetcode182动态口令(将字符的前几个元素放在字符串后面)
算法
老鼠只爱大米12 小时前
LeetCode经典算法面试题 #98:验证二叉搜索树(递归法、迭代法等五种实现方案详解)
算法·leetcode·二叉树·递归·二叉搜索树·迭代
疯狂的喵17 小时前
C++编译期多态实现
开发语言·c++·算法
scx2013100417 小时前
20260129LCA总结
算法·深度优先·图论
2301_7657031417 小时前
C++中的协程编程
开发语言·c++·算法
m0_7487080517 小时前
实时数据压缩库
开发语言·c++·算法
小魏每天都学习18 小时前
【算法——c/c++]
c语言·c++·算法
智码未来学堂18 小时前
探秘 C 语言算法之枚举:解锁解题新思路
c语言·数据结构·算法
Halo_tjn18 小时前
基于封装的专项 知识点
java·前端·python·算法
春日见19 小时前
如何避免代码冲突,拉取分支
linux·人工智能·算法·机器学习·自动驾驶