拼多多24届暑期实习真题

news/2024/11/18 12:41:03/

1. 题目描述:

多多开了一家自助餐厅,为了更好地管理库存,多多君每天需要对之前的课流量数据进行分析,并根据客流量的平均数和中位数来制定合理的备货策略。

2. 输入输出描述:

输入描述:

输入共两行:

第一行一个整数N,表示餐厅营业总天数(0 < N<=200,000),

第二行共N个整数,分别表示第i天的课流量Ri(0 <= Ri <= 1,000,000);

输出描述:

输出共两行:

第一行长度为N,其中第i个值表示前i天客流量的平均值。

第二行长度为N,其中第i个值表示前i天客流量的中位数。

示例1:(输入输出示例仅供调试,后台判题数据一般不包含示例。)

输入:

5

1 2 3 4 10

输出:

1 2 2 3 4

1 2 2 3 3

3. 题解 

思想:

1) 求中位数的思路见力扣295题:数据流的中位数​​​​​​

a. 建立一个大根堆,一个小根堆。大根堆存储小于当前中位数,小根堆存储大于等于当前中位数。且小根堆的大小永远都比大根堆大1或相等。
b. 根据上述定义,我们每次可以通过小根堆的堆顶或者两个堆的堆顶元素的平均数求出中位数。
c. 维护时,如果新加入的元素大于等于当前的中位数,则加入小根堆;否则加入大根堆。然后如果发现两个堆的大小关系不满足上述要求,则可以通过弹出一个堆的元素放到另一个堆中。

2)求平均值是采用前缀和。

3)  有个坑是向上取整。如果分母没有1.0 或者2.0就会变成int型,这时候你再用ceil也不会有向上取整的效果了。因为是先变成了整数,再向上取整。 

C++代码:

#include <iostream>
#include <queue>
#include <cmath>
using namespace std;int main() {int n;cin >> n;int R[n];for (int i = 0; i < n; i++) {cin >> R[i];}// 求前缀和int prefixSum[n];prefixSum[0] = R[0];for (int i = 1; i < n; i++) {prefixSum[i] = prefixSum[i - 1] + R[i];}// 计算平均值和中位数double avg[n];int median[n];//用两个堆维持中位数的位置,//down是一个大顶堆,存储小于等于中位数的值。//up是一个小顶堆,存储大于中位数的值。//down存储的数量最多比up多一个。(人为规定)。priority_queue<int> down;priority_queue<int, vector<int>, greater<int>> up;for(int i = 0; i < n; i++) {if (down.empty() || R[i] <= down.top()) {down.push(R[i]);if (down.size() > up.size() + 1) {up.push(down.top());down.pop();}} else {up.push(R[i]);if (up.size() > down.size()) {down.push(up.top());up.pop();}}if((down.size() + up.size()) % 2){median[i] = down.top();}else{median[i] = ceil((down.top()+up.top())/2.0);//向上取整}avg[i] = ceil(prefixSum[i]/(i + 1.0));//向上取整}// 输出结果for (int i = 0; i < n; i++) {cout << (int) avg[i] << " ";}cout << endl;for (int i = 0; i < n; i++) {cout << median[i] << " ";}cout << endl;return 0;
}

Java代码:(ChatGPT转换的)

import java.util.PriorityQueue;
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();int[] R = new int[n];for (int i = 0; i < n; i++) {R[i] = sc.nextInt();}// 求前缀和int[] prefixSum = new int[n];prefixSum[0] = R[0];for (int i = 1; i < n; i++) {prefixSum[i] = prefixSum[i - 1] + R[i];}// 计算平均值和中位数double[] avg = new double[n];int[] median = new int[n];PriorityQueue<Integer> down = new PriorityQueue<>((a, b) -> b - a);PriorityQueue<Integer> up = new PriorityQueue<>();for (int i = 0; i < n; i++) {if (down.isEmpty() || R[i] <= down.peek()) {down.offer(R[i]);if (down.size() > up.size() + 1) {up.offer(down.poll());}} else {up.offer(R[i]);if (up.size() > down.size()) {down.offer(up.poll());}}if ((down.size() + up.size()) % 2 == 1) {median[i] = down.peek();} else {median[i] = (int) Math.ceil((down.peek() + up.peek()) / 2.0);}avg[i] = Math.ceil(prefixSum[i] / (i + 1.0));}// 输出结果for (int i = 0; i < n; i++) {System.out.print((int) avg[i] + " ");}System.out.println();for (int i = 0; i < n; i++) {System.out.print(median[i] + " ");}System.out.println();}
}

 


http://www.ppmy.cn/news/32295.html

相关文章

字符串函数和内存函数

&#x1f355;博客主页&#xff1a;️自信不孤单 &#x1f36c;文章专栏&#xff1a;C语言 &#x1f35a;代码仓库&#xff1a;破浪晓梦 &#x1f36d;欢迎关注&#xff1a;欢迎大家点赞收藏关注 字符串函数和内存函数 文章目录字符串函数和内存函数前言1. 字符串函数介绍1.1 s…

从参数数量视角理解深度学习神经网络算法 DNN, CNN, RNN, LSTM 以python为工具

从参数数量视角理解深度学习神经网络算法 DNN, CNN, RNN, LSTM 以python为工具 文章目录1. 神经网络数据预处理1.1 常规预测情景1.2 文本预测场景2.全连接神经网络 DNN3.卷积神经网络CNN4.循环神经网络 RNN5.长短期记忆神经网络 LSTMʚʕ̯•͡˔•̯᷅ʔɞʚʕ̯•͡˔•̯᷅ʔ…

快速排序【算法解析,代码模板】

快排的思想是基于 分治 思想的一种排序方法&#xff0c;核心思路分为以下几步&#xff1a; ① 确定 左右边界 l 和 r ② 设置x&#xff0c;值可以是q[l] , q[r] 或者q[(l r) / 2] ③ 递归排序左右区间 我们可能并不清楚x到底在待排数组的哪个位置&#xff0c;但是我们基于…

想要成为高级网络工程师,只需要具备这几点

首先&#xff0c;成为高级网络工程师的目的&#xff0c;就是为了搞钱。高级网络工程师肯定是不缺钱的&#xff0c;但成为高级网络工程师你一定要具备以下几点&#xff1a;第一 心态作为一个高级网工&#xff0c;首先你必须情绪要稳定&#xff0c;在碰到重大故障的时候不慌&…

MyBatis开发环境搭建

1.创建工程 2.引入相关的依赖 pom.xml <dependencies><!--1.引入mybatis包--><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.6</version></dependency><!--2.单元…

Java八股文(Java多线程面试题)

并行和并发的区别&#xff1f;&#xff08;1&#xff09;并行是指两个或者多个事件在同一时刻发生&#xff1b;而并发是指两个或多个事件在同一时间间隔发生&#xff1b;&#xff08;2&#xff09;并行是在不同实体上的多个事件&#xff0c;并发是在同一实体上的多个事件&#…

昨天某读者拿到华为OD岗位offer,今天来分享一下经验,包含华为OD机试

来自读者投稿&#xff0c;已经拿到华为 OD 开发岗位 offer&#xff0c;询问了一些问题&#xff0c;下面是他的一些经验。 文章目录华为 OD 投递简历华为 OD 机试分数OD 机试通过之后&#xff0c;收到综合测评OD 技术面&#xff08;时长 1 小时左右&#xff09;主管/HR 面试&…

如何提高soc算法精度

当今电动汽车技术已经成熟&#xff0c;BMS&#xff08;Battery Management System&#xff0c;电池管理系统&#xff09;是其中非常重要的组成部分。在电池的使用过程中&#xff0c;如何准确地测量电池的剩余电量是非常重要的&#xff0c;这就需要一个高精度的SOC&#xff08;S…