当前位置: 首页 > news >正文

【NOIP普及组】明明的随机数

【NOIP普及组】明明的随机数

      • C语言实现
      • C++实现
      • Java实现
      • Python实现


💐The Begin💐点点关注,收藏不迷路💐

明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了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];// 读取随机数的个数Nscanf("%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;// 读取随机数的个数Nstd::cin >> n;// 读取N个随机数并存入vectorfor (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)))

在这里插入图片描述


💐The End💐点点关注,收藏不迷路💐

http://www.mrgr.cn/news/66288.html

相关文章:

  • Windows 10 安装使用Docker踩过的坑和解决-31/10/2024
  • Web Broker(Web服务应用程序)入门教程(2)
  • C 语言标准库 - <assert.h>
  • 【用Java学习数据结构系列】泛型上界与通配符上界
  • VSCode 1.82之后的vscode server离线安装
  • Jenkins 构建时候提示超时错误被终止
  • 华为HarmonyOS借助AR引擎帮助应用实现虚拟与现实交互的能力3-获取设备位姿
  • 腾讯混元宣布大语言模型和3D模型正式开源
  • 外包干了6年,技术退步明显.......
  • 小张求职记五
  • C++【string类,模拟实现string类】
  • 数码管驱动电路音响LED驱动芯片VK1640
  • 【通俗理解】自由能与熵的关系是怎样的? ——从热力学第二定律看自由能最小化与熵最大化的趋势
  • C++ <string> 标头文件详解
  • 多线程--模拟实现定时器--Java
  • 了解分布式数据库系统中的CAP定理
  • 【初阶数据结构与算法】复杂度分析练习之轮转数组(多种方法)
  • 华为HarmonyOS借助AR引擎帮助应用实现虚拟与现实交互的能力2-管理AR会话
  • C++ 高效率整型大数运算项目优化——内置类型存储与计算
  • 数据结构——二叉树(续集)
  • 在Android开发中如何使用OCR获取当前屏幕中的文本?
  • Nop入门:极简AOP实现
  • Android问题 -- DJ多多的下载文件在哪里? DJ多多dat格式转换为mp3
  • LoRA(Low-Rank Adaptation)的工作机制 - 在 GPT-2 的注意力层中添加 LoRA 低秩适配器
  • Git遇到“fatal: bad object refs/heads/master - 副本”问题的解决办法
  • 基于 GADF+Swin-CNN-GAM 的高创新轴承故障诊断模型