2024年4月12日饿了么春招实习试题【第一题:质数和合数】-题目+题解+在线评测【模拟】

2024年4月12日饿了么春招实习试题【第一题:质数和合数】-题目+题解+在线评测【模拟】

题目描述:

塔子哥有一个数组,她想知道这个数组不同的质数和不同的合数共有多少个。

合数是指在大于1的整数中除了能被1和本身整除外,还能被其他数 (0除外) 整除的数。

输入描述

第一行入一个整数 1 < = n < = 2 × 1 0 5 1<=n<=2\times 10^5 1<=n<=2×105表示数组长度。 第二行输入 n个整数表示数组 a i ( 1 < = a i < = 2 × 1 0 5 ) a_i(1<=a_i<=2\times 10^5) ai(1<=ai<=2×105)

输出描述

输出一个整数。

样例

输入

auto 复制代码
3
20 2 4

输出

auto 复制代码
3

说明

不同的合数有20和4,质数有2,所以有3种。

OJ链接:
https://codefun2000.com/p/P1816

解题思路一:质数+合数=除去1的所有正整数

除了1以外,一个大于0的整数要么是质数要么是合数,所以只需要计算集合的元素数量即可。如果数组包含1,则减去一个元素。

python 复制代码
n = int(input())
nums = list(map(int, input().split()))
st = set(nums)
# if 1 in st:
#     print(len(st) - 1)
# else:
#     print(len(st))
print(len(st) - (1 if 1 in st else 0))

时间复杂度:O(n)

空间复杂度:O(n)

解题思路二:java

python 复制代码
import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;

public class UniqueIntegers {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        Set<Integer> sett = new HashSet<>();
        for (int i = 0; i < n; i++) {
            int value = scanner.nextInt();
            sett.add(value);
        }
        int count = sett.size();
        if (sett.contains(1)) {
            count -= 1;
        }
        System.out.println(count);
    }
}

时间复杂度:O(n)

空间复杂度:O(1)

解题思路三:c++

python 复制代码
#include <iostream>
#include <set>
using namespace std;
int main() {
    int n;
    cin >> n;
    set<int> sett;
    for (int i = 0; i < n; i++) {
        int value;
        cin >> value;
        sett.insert(value);
    }
    int count = sett.size();
    if (sett.find(1) != sett.end()) {
        count--;
    }
    cout << count << endl;
    return 0;
}

时间复杂度:O(n)

空间复杂度:O(1)

相关推荐
宇宙李11 分钟前
2024java面试-软实力篇
面试·职场和发展
重生之我要进大厂15 分钟前
LeetCode 876
java·开发语言·数据结构·算法·leetcode
测试界柠檬28 分钟前
接口测试到底测试什么?
自动化测试·软件测试·功能测试·程序人生·职场和发展·单元测试·压力测试
Amo Xiang31 分钟前
Python 常用模块(四):shutil模块
开发语言·python
Happy鱿鱼1 小时前
C语言-数据结构 有向图拓扑排序TopologicalSort(邻接表存储)
c语言·开发语言·数据结构
KBDYD10101 小时前
C语言--结构体变量和数组的定义、初始化、赋值
c语言·开发语言·数据结构·算法
计算机学姐1 小时前
基于python+django+vue的影视推荐系统
开发语言·vue.js·后端·python·mysql·django·intellij-idea
Crossoads1 小时前
【数据结构】排序算法---桶排序
c语言·开发语言·数据结构·算法·排序算法
扎克begod1 小时前
JAVA并发编程系列(9)CyclicBarrier循环屏障原理分析
java·开发语言·python
自身就是太阳1 小时前
2024蓝桥杯省B好题分析
算法·职场和发展·蓝桥杯