380.O(1) 时间插入、删除和获取随机元素

实现RandomizedSet 类:

RandomizedSet() 初始化 RandomizedSet 对象
bool insert(int val) 当元素 val 不存在时,向集合中插入该项,并返回 true ;否则,返回 false 。
bool remove(int val) 当元素 val 存在时,从集合中移除该项,并返回 true ;否则,返回 false 。
int getRandom() 随机返回现有集合中的一项(测试用例保证调用此方法时集合中至少存在一个元素)。每个元素应该有 相同的概率 被返回。
你必须实现类的所有函数,并满足每个函数的 平均 时间复杂度为 O(1) 。

C++

#include <iostream>
#include <cstring>
#include <cmath>
#include <vector>
#include <list>
#include <set>
#include <map>
#include <unordered_map>
#include <stack>
#include <queue>
#include <thread>
#include <mutex>
#include <algorithm>
using namespace std;class TheClass{vector<int> nums;unordered_map<int,int> map;	public: TheClass(){}public: bool insert(int val){if( !map.count(val) ){int index=nums.size();nums.push_back(val);map[val]=index;return true;}else{return false;}}public: bool remove(int val){if( map.count(val) ){int index=map[val];nums[index]=nums[nums.size()-1];nums.pop_back();map[nums[index]]=index;map.erase(val);return true;}else{return false;}}public: int getRandom(){int index=rand()%nums.size();return nums[index];}public: void print(){printf("\n");for( int i=0;i<nums.size();i++ ){printf("  %d",nums[i]);}printf("\n");}};int main(){TheClass tc;bool result=tc.insert(1);tc.print();tc.remove(2);tc.print();tc.insert(2);tc.print();tc.remove(1);tc.print();tc.insert(2);tc.print();return 0;
}

时间复杂度

O ( 1 ) O(1) O(1)

空间复杂度

O ( n ) O(n) O(n)

Java

import java.util.Scanner;
import java.lang.Math;
import java.util.Map;
import java.util.HashMap;
import java.util.List;
import java.util.ArrayList;public class java380{List<Integer> nums;Map<Integer,Integer> maps;	public java380(){nums=new ArrayList<Integer>();maps=new HashMap<Integer,Integer>();}	public boolean insert(int val){if( !maps.containsKey(val) ){int index=nums.size();nums.add(val);maps.put(val,index);return true;	}else{return false;}}public boolean remove(int val){if( maps.containsKey(val) ){int index=maps.get(val);nums.set(index,nums.get(nums.size()-1));maps.put(nums.get(nums.size()-1),index);nums.remove(nums.size()-1);maps.remove(val);return true;}else{return false;}}public int getRandom(){int index=(int)(Math.random()*nums.size());return nums.get(index);		}public void print(){System.out.println("");for( int i=0;i<nums.size();i++ ){System.out.print("  "+nums.get(i));}System.out.println("");}public static void main(String [] args){java380 j38=new java380();j38.insert(1);j38.print();j38.remove(2);j38.print();j38.insert(2);j38.print();j38.remove(1);j38.print();j38.insert(2);j38.print();}
}

时间复杂度

O ( 1 ) O(1) O(1)

空间复杂度

O ( n ) O(n) O(n)

Python

import random;
class python380:def __init__(self):self.nums=[];self.maps={};def insert(self,val: int) -> bool:if val not in self.nums:index=len(self.nums);self.maps[val]=index;self.nums.append(val);return True;else:return False;def remove(self,val: int) -> bool:if val in self.nums:index=self.maps[val];self.nums[index]=self.nums[len(self.nums)-1];self.maps[self.nums[len(self.nums)-1]]=index;del self.maps[val];self.nums.pop(len(self.nums)-1);return True;else:return False;def getRandom(self) -> int:index=random.randint(0,len(self.nums));return self.nums[index];def p(self):print("\n");for val in self.nums:print("  "+str(val));print("\n");	p38=python380();
p38.insert(1);
p38.p();
p38.remove(2);
p38.p();
p38.insert(2);
p38.p();
p38.remove(1)
p38.p();
p38.insert(2);
p38.p();

时间复杂度

O ( 1 ) O(1) O(1)

空间复杂度

O ( n ) O(n) O(n)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/67028.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《异步编程之美》— 全栈修仙《Java 8 CompletableFuture 对比 ES6 Promise 以及Spring @Async》

哈喽&#xff0c;大家好&#xff01;在平常开发过程中会遇到许多意想不到的坑&#xff0c;本篇文章就记录在开发过程中遇到一些常见的问题&#xff0c;看了许多博主的异步编程&#xff0c;我只能说一言难尽。本文详细的讲解了异步编程之美&#xff0c;是不可多得的好文&#xf…

python 3个线程轮流打印A、B、C

要实现 Python 中三个线程轮流打印 A、B、C 的效果&#xff0c;可以使用 threading 模块和 Condition 或 Lock 来同步线程。以下是使用 Condition 的解决方案&#xff1a; 代码实现 import threading# 初始化条件变量 condition threading.Condition() current 0 # 共享变…

《机器学习》之K-means聚类

目录 一、简介 二、K-means聚类实现步骤 1、初始化数据点、确定K值 2、通过距离分配数据点 3、更新簇中心 4、 迭代更新 三、聚类效果评价方式 1、轮廓系数的定义 2、整体轮廓系数 3、使用场景 4、优点 5、缺点 6、代码实现方法 四、K-means聚类代码实现 1、API接…

MVC执行流程

&#xff08;1&#xff09;用户通过浏览器&#xff08;客户端&#xff09;向服务端&#xff08;后端&#xff09;发送请求&#xff0c;请求会被前端控制器DispatcherServlet拦截。 &#xff08;2&#xff09;DispatcherServlet拦截到请求后&#xff0c;会调用处理器映射器&…

springboot和vue配置https请求

项目场景&#xff1a; 代码发布到线上使用https请求需要配置ssl证书&#xff0c;前后端都需要修改。 问题描述 如图&#xff0c;我们在调用接口时报如下错误&#xff0c;这就是未配置ssl但是用https请求产生的问题。 解决方案&#xff1a; 前端&#xff1a;在vite.config.js文…

单细胞组学大模型(8)--- scGenePT,scGPT和GenePT的结合,实验数据和文本数据的交融模型

–https://doi.org/10.1101/2024.10.23.619972 研究团队和单位 Theofanis Karaletsos–Head Of AI - Science at Chan Zuckerberg Initiative &#xff08;Chan Zuckerberg Initiative是扎克伯格和他妻子Chan成立的科研&教育机构&#xff09; 研究简介 研究背景&…

改进萤火虫算法之八:量子萤火虫算法(Quantum-behaved Firfly Algorithm,QFA)

量子萤火虫算法(Quantum-behaved Firfly Algorithm,QFA)是对萤火虫算法的一种改进,旨在提升萤火虫个体的搜索能力。以下是对量子萤火虫算法的详细介绍: 一、萤火虫算法基础 萤火虫算法(Firefly Algorithm,FA)是一种基于群体智能的优化算法,由剑桥大学的Xin-She Yang在…

C++----STL(string)

引言&#xff1a;STL简介 什么是STL STL(standard template libaray-标准模板库)&#xff1a; 是 C标准库的重要组成部分&#xff08;注意&#xff1a;STL只是C标准库里的一部分&#xff0c;cin和cout也是属于C标准库的&#xff09;&#xff0c;不仅是一个可复用的组件库&…

基于“大型园区”网络设计

基于“大型园区”网络设计 目 录 第1章 项目概述1 1.1 项目背景1 1.2 公司概况1 1.3 网络现状2 第2章 需求分析4 2.1 部门需求4 2.2 配置需求4 2.3 网络功能需求5 第3章 网络设计6 3.1 建设原则6 3.2 网络拓扑结构6 3.3 IP地址和VLAN划分8 3.4 核心层设计9 3.5 …

宝塔面板 申请证书后 仍然提示不安全

证书显示有效&#xff0c;但是网站显示不安全 导致的原因是引入静态文件使用的是HTTP&#xff0c;查看方法为F12打开console控制台 可以看到静态文件全部都是HTTP 网站采用wordpress搭建&#xff0c;基于问题解决&#xff0c;其他方式搭建也是一样&#xff0c;处理掉所有的H…

BO-SVM贝叶斯算法优化支持向量机的数据多变量时间序列预测

BO-SVM贝叶斯算法优化支持向量机的数据多变量时间序列预测 目录 BO-SVM贝叶斯算法优化支持向量机的数据多变量时间序列预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab基于BO-SVR贝叶斯算法优化支持向量机的数据多变量时间序列预测&#xff0c;加入5折交叉验…

深入 Flutter 和 Compose 在 UI 渲染刷新时 Diff 实现对比

众所周知&#xff0c;不管是什么框架&#xff0c;在前端 UI 渲染时&#xff0c;都会有构造出一套相关的渲染树&#xff0c;并且在 UI 更新时&#xff0c;为了尽可能提高性能&#xff0c;一般都只会进行「差异化」更新&#xff0c;而不是对整个 UI Tree 进行刷新&#xff0c;所以…

http和https有哪些不同

http和https有哪些不同 1.数据传输的安全性&#xff1a;http非加密&#xff0c;https加密 2.端口号&#xff1a;http默认80端口&#xff0c;https默认443端口 3.性能&#xff1a;http基于tcp三次握手建立连接&#xff0c;https在tcp三次握手后还有TLS协议的四次握手确认加密…

html辅助标签与样式表

一、HTML其它常用标签 1.meta标签 &#xff08;1&#xff09;meta标签是一个特殊的HTML标签&#xff0c;提供有关网页的信息&#xff0c;如作者姓名、公司名称和联系信息等 &#xff08;2&#xff09;许多搜索引擎都使用meta标签 <head> <meta name"keyword…

中等难度——python实现电子宠物和截图工具

import io # 文件处理 import nt # windows nt 库直接获取对应的磁盘空间 import time # 时间 import zlib # 加解密 import ctypes # 调用 import struct # 处理字节二进制 import base64 # 编解码 import threading # 线程 import tkinter as tk # tk from datetime…

3D目标检测数据集——Nusence数据集

链接地址 [官网] nuScenes[arXiv] nuScenes: A multimodal dataset for autonomous driving[GitHub] nuScenes devkitnuScenes devkit教程数据集概述 2.1 数据采集 2.1.1 传感器配置 nuScenes的数据采集车辆为Renault Zoe迷你电动车,配备6个周视相机&#x

lerna使用指南

lerna版本 以下所有配置命令都是基于v8.1.9&#xff0c;lerna v5 v7版本差别较大&#xff0c;在使用时&#xff0c;注意自身的lerna版本。 lerna开启缓存及缓存配置 nx缓存是v5版本以后才有的&#xff0c;小于该版本的无法使用该功能。 初始化配置 缓存配置文件nx.json&am…

neo4j 安装 (提供镜像下载方式

neo4j 安装 docker # 获取镜像 docker pull neo4j:community# 启动 docker run \--publish7474:7474 --publish7687:7687 \neo4j:communityfile download 文件下载的方式&#xff0c;访问 URL&#xff1a;https://neo4j.com/deployment-center/ 然后选择对应的平台&#xff…

用Ingress生成route,如何让生成route的insecureEdgeTerminationPolicy 的值为Allow

对于此功能当前还没有实现&#xff0c;相关的新功能添加的 Jira ticket 如下&#xff1a; Annotate the ingress to create the route with the spec.tls.insecureEdgeTerminationPolicy set to Allow 目前已经实现的功能为termination&#xff0c;insecureEdgeTerminationPol…

JAVA安全编码规范

1. 数据校验 对外部输入进行校验入参的合法性&#xff0c; 防止内存越界&#xff0c;命令注入&#xff0c;SQL注入&#xff0c;格式化字符串漏洞 校验长度&#xff0c;范围&#xff0c;输入校验采用白名单形式 校验前做归一化处理&#xff0c;使用java.text.Normalizer的n…