华为机试-101-入门-HJ101.输入整型数组和排序标识,对其元素按照升序或降序进行排序
一、描述
输入整型数组和排序标识,对其元素按照升序或降序进行排序
数据范围: 1 ≤ n ≤ 1000 ,元素大小满足 0 ≤ val ≤ 100000
1.1、输入描述
第一行输入数组元素个数
第二行输入待排序的数组,每个数用空格隔开
第三行输入一个整数0或1。0代表升序排序,1代表降序排序
1.2、输出描述
输出排好序的数字
二、示例
2.1、示例1
输入:
8
1 2 4 9 3 55 64 25
0
输出:
1 2 3 4 9 25 55 64
2.2、示例2
输入:
5
1 2 3 4 5
1
输出:
5 4 3 2 1
三、答案(java)
3.1、方法一
package com.tzq.hwod;
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
int n = sc.nextInt();// 接收数组长度
int[] arr = new int[n];// 创建数组
for (int i = 0; i < n; i++) {// 数组填入
arr[i] = sc.nextInt();
}
int flag = sc.nextInt();// 接收排序标识
Arrays.sort(arr);// 数组排序
if (flag == 0) {// 正序输出
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
} else {// 逆序输出
for (int i = arr.length - 1; i >= 0; i--) {
System.out.print(arr[i] + " ");
}
}
}
}
}
四、答案(python 3)
4.1、方法一
#!/usr/bin/python
# -*- coding: UTF-8 -*-
n = int(input())
ls = list(map(int, input().split())) # 需要转成整数,才能排序
rnk = int(input())
if rnk == 0:
ls.sort()
ls = map(str,ls) # 需要转回字符串,才能拼接
print(' '.join(ls))
elif rnk == 1:
ls.sort(reverse=True)
ls = map(str, ls)
print(' '.join(ls))