明显想在学校中请一些同砚一起做一项问卷观察,为了实行的客观性,他先用盘算机天生了N个1到1000之间的随机整数(N≤100),对于此中重复的数字,只保存一个,把别的类似的数去掉,差别的数对应着差别的弟子的学号。然后再把这些数从小到大排序,按照排好的序次去找同砚做观察。请你帮忙明显完成“去重”与“排序”的工作。
输入
输入2行,第1举动1个正整数,表现所天生的随机数的个数N,第2行有N个用空格隔开的正整数,为所产生的随机数。
输出
输出2行,第1举动1个正整数M,表现不类似的随机数的个数。第2举动M个用空格隔开的正整数,为从小到大排好序的不类似的随机数。
样例输入
- 10
- 20 40 32 67 40 20 89 300 400 15
复制代码 样例输出
- 8
- 15 20 32 40 67 89 300 400
复制代码 C语言实现
#include <stdio.h>
#include <stdlib.h>
#define MAX_N 100
// 比力函数,用于qsort
int compare(const void * a, const void * b) {
return ( (int)a - (int)b );
}
int main() {
int n;
int numbers[MAX_N];
int unique_numbers[MAX_N];
- // 读取随机数的个数N
- scanf("%d", &n);
- // 读取N个随机数
- for (int i = 0; i < n; i++) {
- scanf("%d", &numbers[i]);
- }
- int unique_count = 0;
- // 遍历所有随机数,进行去重操作
- for (int i = 0; i < n; i++) {
- int is_duplicate = 0;
- for (int j = 0; j < unique_count; j++) {
- if (numbers[i] == unique_numbers[j]) {
- is_duplicate = 1;
- break;
- }
- }
- if (!is_duplicate) {
- unique_numbers[unique_count] = numbers[i];
- unique_count++;
- }
- }
- // 对去重后的数组进行排序
- qsort(unique_numbers, unique_count, sizeof(int), compare);
- // 输出不相同的随机数的个数
- printf("%d\n", unique_count);
- // 输出排好序的不相同的随机数
- for (int i = 0; i < unique_count; i++) {
- printf("%d ", unique_numbers[i]);
- }
- printf("\n");
- return 0;
复制代码 }
C++实现
#include <iostream>
#include <algorithm>
#include <vector>
int main() {
int n;
std::vector<int> numbers;
std::vector<int> unique_numbers;
- // 读取随机数的个数N
- std::cin >> n;
- // 读取N个随机数并存入vector
- for (int i = 0; i < n; ++i) {
- int num;
- std::cin >> num;
- numbers.push_back(num);
- }
- int unique_count = 0;
- // 遍历所有随机数,进行去重操作
- for (int num : numbers) {
- if (std::find(unique_numbers.begin(), unique_numbers.end(), num) == unique_numbers.end()) {
- unique_numbers.push_back(num);
- unique_count++;
- }
- }
- // 对去重后的vector进行排序
- std::sort(unique_numbers.begin(), unique_numbers.end());
- // 输出不相同的随机数的个数
- std::cout << unique_count << std::endl;
- // 输出排好序的不相同的随机数
- for (int num : unique_numbers) {
- std::cout << num << " ";
- }
- std::cout << std::endl;
- return 0;
复制代码 }
Java实现
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Scanner;
public class Main {
- public static void main(String[] args) {
- Scanner scanner = new Scanner(System.in);
- int n = scanner.nextInt();
- int[] numbers = new int[n];
- // 读取N个随机数
- for (int i = 0; i < n; i++) {
- numbers[i] = scanner.nextInt();
- }
- // 使用HashSet进行去重
- HashSet<Integer> uniqueSet = new HashSet<>();
- for (int num : numbers) {
- uniqueSet.add(num);
- }
- // 将HashSet中的元素转换为数组以便排序
- Integer[] uniqueArray = uniqueSet.toArray(new Integer[0]);
- // 对去重后的数组进行排序
- Arrays.sort(uniqueArray);
- // 输出不相同的随机数的个数
- System.out.println(uniqueArray.length);
- // 输出排好序的不相同的随机数
- for (int num : uniqueArray) {
- System.out.print(num + " ");
- }
- System.out.println();
- scanner.close();
- }
复制代码 }
Python实现
- n = int(input())
- # 读取N个随机数
- numbers = list(map(int, input().split()))
- # 使用集合进行去重
- unique_numbers = list(set(numbers))
- # 对去重后的列表进行排序
- unique_numbers.sort()
- # 输出不相同的随机数的个数
- print(len(unique_numbers))
- # 输出排好序的不相同的随机数
- print(" ".join(map(str, unique_numbers)))
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!qidao123.com:ToB企服之家,中国第一个企服评测及软件市场,开放入驻,技术点评得现金 |