news 2026/4/16 18:49:03

小明统计数组

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
小明统计数组
题目描述

小明最近喜欢上数组统计,但是他遇到了一道难题,题目如下:

最初数列是空的,那么一共有下面五种操作:

  1. a x 表示向数列里面增加数值为x的数;

  2. d x 表示删除数列里面数值为x的数;

  3. I 表示删除数列里面数值最大的数;

  4. m 表示删除数列里面数值最小的数;

  5. q 询问当前数列的和。

保证添加的元素都不不一样,对于删除操作,如果数列里面不存在这个元素,则不进行删除操作。小明不会做这个题,希望寻求你的帮助,聪明的你可以帮助小明解决这个问题吗?

在处理输入的时候要特别注意!题目中操作 3 的操作字符是 大写的 i,而不是小写的 l。

输入格式

第一行输入两个数n,表示操作的数目;

之后n行,每行为题目中描述的五种操作。

输出格式

对于每个询问,输出当前数列的和。

样例

【样例输入】

11 a 1 d 2 q a 2 a 3 a 4 q I q m q

【样例输出】

1 10 6 5
数据范围与提示
样例解释

a 1 增加1到数列里面

d 2 删除数列里面数值为2的元素,因为数列里面没有,所以不进行操作

q 询问,当前数列的和为1

a 2 增加2到数列里面

a 3 增加3到数列里面

a 4 增加4到数列里面

q 询问,当前数列的和为10

I 删除数列里面数值最大的元素,删除4

q 询问,当前数列的和为6

m 删除数列里面数值最小的元素,删除1

q 询问,当前数列的和为5

数据范围

1<=n<=100000

1<=x<=100000且x互不相同

一些想法

在最前面先定义一个关于 set 的迭代器 it,以便后面使用,循环输入字符,然后判断如果字符是‘a’,再输入一个数,在 set 中插入这个数。如果是‘d’,寻找 输入的数 如果不等于最后一个数的后面(就是如果这个数存在 set 中),删除这个数。如果等于 I,it 等于 --end(),就是等于最后一个数(正序排序后的最后一个数,也就是最大的数),如果 set 不为空,删除 it。如果等于‘m’,it等于第一个数(也就是最小的数),如果队列不为空,删除这个数。如果等于‘q’,用迭代器遍历 set,加上每一个数(set所有数之和),输出,换行。

AC代码

#include<bits/stdc++.h> using namespace std; int main(){ int n; cin>>n; set<int> s; set<int>::iterator it; for(int i=1;i<=n;i++){ char a; cin>>a; if(a=='a'){ int d; cin>>d; s.insert(d); } if(a=='d'){ int d; cin>>d; if(s.find(d)!=s.end()) s.erase(d); } if(a=='I'){ it=--s.end(); if(!s.empty()) s.erase(it); } if(a=='m'){ it=s.begin(); if(!s.empty()) s.erase(it); } if(a=='q'){ int sum=0; for(it=s.begin();it!=s.end();it++){ sum+=*it; } cout<<sum<<endl; } } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:18:28

现行析音法

现行析音法 节调质素分析法是把音节分析成由节调与节质构成的音节并且把节质切分成质素序列的方法。在经过节调质素分析后&#xff0c;音节由节调与节质构成&#xff0c;节质在不省略零声母的情况下由声母和韵母构成&#xff0c;韵母分成单质韵母、前长韵母、后长韵母和三质韵…

作者头像 李华
网站建设 2026/4/16 15:51:09

AR.js新API:5分钟开启WebAR开发新时代,让移动端增强现实触手可及

还在为WebAR开发的复杂性而头疼吗&#xff1f;传统的增强现实开发需要处理相机初始化、标记跟踪、三维场景渲染等多个环节&#xff0c;代码量动辄上百行。现在&#xff0c;AR.js的全新API彻底改变了这一现状——通过创新的"会话-锚点"架构&#xff0c;让WebAR开发变得…

作者头像 李华
网站建设 2026/4/15 20:53:46

Linux学习笔记_2025.12.11

Linux学习笔记_2025.12.11 文件属性 ls命令-l#详细信息-a#隐藏文件-d#查看目录本身详细信息-r#逆序显示文件-i#查看inode号-t#查看文件创建时间du #统计文件大小[rootmsdn_cc ~]# du -sh /etc/64M /etc/inode号码df -i #查看总inodedf -h #查看磁盘大小ll -i #查看文件inode号…

作者头像 李华
网站建设 2026/4/15 22:43:24

5个必备技巧:打造企业级人脸识别系统的完整指南

面对日益增长的安全需求&#xff0c;如何构建一个既安全又高效的人脸识别系统&#xff1f;FaceVerificationSDK为你提供了完美的离线解决方案。这个专为Android设备设计的人脸识别SDK&#xff0c;让你无需依赖云端服务&#xff0c;就能实现专业级的人脸检测、活体识别和人脸搜索…

作者头像 李华
网站建设 2026/4/16 13:54:45

串口设备调试利器:RS485/232调试助手深度解析

串口设备调试利器&#xff1a;RS485/232调试助手深度解析 【免费下载链接】RS485232串口调试助手 本仓库提供了一个名为“RS485/232串口调试助手.zip”的资源文件下载。该文件是一个串口调试工具&#xff0c;适用于RS485和RS232串口设备的调试和测试。 项目地址: https://git…

作者头像 李华
网站建设 2026/4/16 14:05:52

终极PWA图标生成解决方案:告别手动裁剪的烦恼

终极PWA图标生成解决方案&#xff1a;告别手动裁剪的烦恼 【免费下载链接】pwa-asset-generator Automates PWA asset generation and image declaration. Automatically generates icon and splash screen images, favicons and mstile images. Updates manifest.json and ind…

作者头像 李华