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

有效的网站建设济源网站建设公司

有效的网站建设,济源网站建设公司,如何网站防止采集,天津建设发展集团有限公司题目: 有 n 个 (id, value) 对,其中 id 是 1 到 n 之间的一个整数,value 是一个字符串。不存在 id 相同的两个 (id, value) 对。 设计一个流,以 任意 顺序获取 n 个 (id, value) 对,并在多次调用时 按 id 递增的顺序…

题目:

有 n 个 (id, value) 对,其中 id 是 1 到 n 之间的一个整数,value 是一个字符串。不存在 id 相同的两个 (id, value) 对。

设计一个流,以 任意 顺序获取 n 个 (id, value) 对,并在多次调用时 按 id 递增的顺序 返回一些值。

实现 OrderedStream 类:

  • OrderedStream(int n) 构造一个能接收 n 个值的流,并将当前指针 ptr 设为 1 。
  • String[] insert(int id, String value) 向流中存储新的 (id, value) 对。存储后:
    • 如果流存储有 id = ptr 的 (id, value) 对,则找出从 id = ptr 开始的 最长 id 连续递增序列 ,并 按顺序 返回与这些 id 关联的值的列表。然后,将 ptr 更新为最后那个  id + 1 。
    • 否则,返回一个空列表。

示例:

输入
["OrderedStream", "insert", "insert", "insert", "insert", "insert"]
[[5], [3, "ccccc"], [1, "aaaaa"], [2, "bbbbb"], [5, "eeeee"], [4, "ddddd"]]
输出
[null, [], ["aaaaa"], ["bbbbb", "ccccc"], [], ["ddddd", "eeeee"]]解释
OrderedStream os= new OrderedStream(5);
os.insert(3, "ccccc"); // 插入 (3, "ccccc"),返回 []
os.insert(1, "aaaaa"); // 插入 (1, "aaaaa"),返回 ["aaaaa"]
os.insert(2, "bbbbb"); // 插入 (2, "bbbbb"),返回 ["bbbbb", "ccccc"]
os.insert(5, "eeeee"); // 插入 (5, "eeeee"),返回 []
os.insert(4, "ddddd"); // 插入 (4, "ddddd"),返回 ["ddddd", "eeeee"]

提示:

  • 1 <= n <= 1000
  • 1 <= id <= n
  • value.length == 5
  • value 仅由小写字母组成
  • 每次调用 insert 都会使用一个唯一的 id
  • 恰好调用 n 次 insert

解法:基于数组和指针的流式处理

解题思路

我们需要设计一个数据结构,能够按 id 递增的顺序返回 (id, value) 对的值。由于 id 是唯一的且范围固定(1 到 n),我们可以使用一个数组来存储这些值,并通过一个指针 ptr 来跟踪当前可以返回的最小 id

具体步骤如下:

  1. 初始化

    • 使用一个大小为 n + 1 的数组 stream 来存储 (id, value) 对。数组的索引直接对应 id,方便快速访问。

    • 初始化指针 ptr 为 1,表示下一个需要返回的 id 是 1

  2. 插入操作

    • 将 (idKey, value) 对存储到数组 stream 的 idKey 位置。

    • 检查当前指针 ptr 是否指向一个已经存储了值的 id。如果是,则从 ptr 开始,依次检查连续的 id 是否已经存储,并将对应的 value 加入结果列表。

    • 更新指针 ptr 为最后一个连续 id 的下一个位置。

    • 返回结果列表。

代码实现

class OrderedStream {
private:vector<string> stream;  // 用于存储 (id, value) 对的数组int ptr;                // 当前指针,指向下一个应该返回的 idpublic:OrderedStream(int n) {stream.resize(n+1);ptr = 1;}vector<string> insert(int idKey, string value) {stream[idKey] = value;vector<string> result;// 如果当前指针指向的 id 已经存储了值,则返回从 ptr 开始的最长连续递增序列while (ptr < stream.size() && !stream[ptr].empty()) {result.push_back(stream[ptr]);ptr++;}return result;}
};/*** Your OrderedStream object will be instantiated and called as such:* OrderedStream* obj = new OrderedStream(n);* vector<string> param_1 = obj->insert(idKey,value);*/

复杂度分析

  1. 时间复杂度

    • 每次调用 insert 方法时,最坏情况下需要遍历从 ptr 开始的所有连续 id,时间复杂度为 O(k),其中 k 是连续 id 的数量。

    • 总体时间复杂度为 O(n),因为每个 id 最多被遍历一次。

  2. 空间复杂度

    • 使用了一个大小为 n + 1 的数组来存储 (id, value) 对,空间复杂度为 O(n)

示例运行

以下是对示例的运行过程分析:

  1. 初始化 OrderedStream(5)stream 数组大小为 6ptr = 1

  2. 调用 insert(3, "cc")

    • 存储 stream[3] = "cc"

    • ptr = 1stream[1] 为空,返回 []

  3. 调用 insert(1, "aa")

    • 存储 stream[1] = "aa"

    • ptr = 1stream[1] 不为空,返回 ["aa"]ptr 更新为 2

  4. 调用 insert(2, "bb")

    • 存储 stream[2] = "bb"

    • ptr = 2stream[2] 不为空,返回 ["bb"]ptr 更新为 3

  5. 调用 insert(5, "ee")

    • 存储 stream[5] = "ee"

    • ptr = 3stream[3] 不为空,返回 ["cc"]ptr 更新为 4

  6. 调用 insert(4, "dd")

    • 存储 stream[4] = "dd"

    • ptr = 4stream[4] 不为空,返回 ["dd", "ee"]ptr 更新为 6

总结

通过使用数组和指针,我们可以高效地实现按 id 递增顺序返回值的功能。该方法的时间复杂度和空间复杂度均为 O(n),能够很好地处理流式数据。

http://www.dtcms.com/wzjs/796807.html

相关文章:

  • 一个网站需要多少空间公众号模板制作精美
  • 传奇电脑版知名seo公司
  • 360网页游戏哈尔滨seo优化教程
  • p2p做网站视频制作平台
  • 大庆市让胡路区规划建设局网站湖南省建设工程造价管理站网站
  • 如何降低网站跳出率网络下载的网站模板能直接上传到虚拟主机
  • wordpress站点图标精准软件
  • 做内贸要在哪个网站找客户百度广州给做网站公司
  • 网站建设哪个公司做得好wordpress 手机端
  • 吉林省招标网官方网站wordpress右边小工具栏
  • 注册德国网站域名网站优化关键词
  • 什么软件做网站做好如何建设正规彩票网站
  • 网站建设公众号管理网站创意
  • 苏州做网站公司找苏州聚尚网络公众号开发者密钥有什么用
  • 温州企业网站排名优化郑州app制作开发
  • 网站建设一般多少钱比较合适网站建设与网页设计从入门到精通 素材下载
  • 重庆大学建设管理与房地产学院网站杭州建设信用平台
  • 厦门企业网站建设公司用vs2012怎么做网站
  • ip下的网站吗山东建设管理局网站
  • 做外贸需要有自己的网站吗网站建站授权模板下载
  • 微网站建设价格百度下载app下载
  • 查网站空间商怎样利用互联网进行网络推广
  • 网站建设专家论证会网站做淘宝客
  • 数据交易网站开发中国建设银行英语网站
  • 天津网站营销建设部资质申报网站
  • 如何做好网站关键词布局asp net做购物网站
  • 室内设计网站大全网站简单的网站设计开发
  • 网站建设确认函seo的课谁讲的好
  • 免费网站统计工具百度营销后台
  • h5网站还有哪些深圳建材公司app