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

沈阳做网站百度竞价排名广告定价

沈阳做网站,百度竞价排名广告定价,番禺定制型网站建设,网站的网络营销推广方案LeetCode 第158题:用Read4读取N个字符 II 题目描述 给你一个文件,并且该文件只能通过给定的 read4 方法来读取,请实现一个方法来读取 n 个字符。 read4 方法: API read4 可以从文件中读取 4 个连续的字符,并且将它…

LeetCode 第158题:用Read4读取N个字符 II

题目描述

给你一个文件,并且该文件只能通过给定的 read4 方法来读取,请实现一个方法来读取 n 个字符。

read4 方法:

  • API read4 可以从文件中读取 4 个连续的字符,并且将它们写入缓存数组 buf 中。
  • 返回值为实际读取的字符个数。

注意:read4() 有自己的文件指针,就像 C 语言中的 FILE *fp 一样。

难度

困难

题目链接

点击在LeetCode中查看题目

示例

示例 1:

输入: file = "abc", n = 4
输出: 3
解释: 当执行你的 read 方法后,buf 需要包含 "abc"。 文件一共 3 个字符,因此返回 3。 注意 "abc" 是文件的内容,不是 buf 的内容。

示例 2:

输入: file = "abcde", n = 5
输出: 5
解释: 当执行你的 read 方法后,buf 需要包含 "abcde"。文件共 5 个字符,因此返回 5。

示例 3:

输入: file = "abcdABCD1234", n = 12
输出: 12
解释: 当执行你的 read 方法后,buf 需要包含 "abcdABCD1234"。文件一共 12 个字符,因此返回 12。

示例 4:

输入: file = "leetcode", n = 5
输出: 5
解释: 当执行你的 read 方法后,buf 需要包含 "leetc"。文件中一共 5 个字符,因此返回 5。

提示

  • 1 <= file.length <= 500
  • n >= 1
  • 你 不能 直接操作该文件,只能通过 get 方法来获取文件内容。
  • 请 不要 修改输出结果数组。
  • 假定所有字符都是 ASCII 码表中的字符。

解题思路

方法:队列

使用队列存储未使用的字符。
关键点:

  1. 使用队列存储read4读取的未使用字符
  2. 当队列为空时,使用read4读取新的字符
  3. 从队列中取出字符直到达到目标字符数或队列为空
  4. 处理边界情况
  5. 返回实际读取的字符数

时间复杂度:O(n),其中n是要读取的字符数。
空间复杂度:O(1),只需要固定大小的队列。

代码实现

C# 实现

public class Solution {private Queue<char> queue = new Queue<char>();public int Read(char[] buf, int n) {int total = 0;char[] temp = new char[4];while (total < n) {if (queue.Count == 0) {int count = Read4(temp);if (count == 0) break;for (int i = 0; i < count; i++) {queue.Enqueue(temp[i]);}}if (queue.Count == 0) break;buf[total++] = queue.Dequeue();}return total;}
}

Python 实现

class Solution:def __init__(self):self.queue = []def read(self, buf: List[str], n: int) -> int:total = 0temp = [None] * 4while total < n:if not self.queue:count = read4(temp)if count == 0:breakself.queue.extend(temp[:count])if not self.queue:breakbuf[total] = self.queue.pop(0)total += 1return total

C++ 实现

class Solution {
private:queue<char> q;public:int read(char *buf, int n) {int total = 0;char temp[4];while (total < n) {if (q.empty()) {int count = read4(temp);if (count == 0) break;for (int i = 0; i < count; i++) {q.push(temp[i]);}}if (q.empty()) break;buf[total++] = q.front();q.pop();}return total;}
};

性能分析

各语言实现的性能对比:

实现语言执行用时内存消耗特点
C#92 ms38.2 MB实现简洁,性能适中
Python156 ms16.8 MB代码最简洁
C++24 ms9.6 MB性能最优

补充说明

代码亮点

  1. 使用队列存储未使用的字符
  2. 处理了各种边界情况
  3. 代码结构清晰,易于维护

常见错误

  1. 没有处理文件结束的情况
  2. 没有处理n大于文件长度的情况
  3. 队列为空时的处理不当

相关题目

  • 157. 用Read4读取N个字符
  • 68. 文本左右对齐
  • 43. 字符串相乘
http://www.dtcms.com/wzjs/287025.html

相关文章:

  • 厦门做企业网站比较好的公司b2b免费外链发布
  • 小贷做网站google网站入口
  • 长沙专业做网站公司哪家好seo属于技术还是营销
  • 怎么在家做网站网络营销策略的特点
  • 经营阅读网站需要怎么做自己做网站需要什么条件
  • 个人服务器搭建做网站信息流广告加盟代理
  • java怎么做网站多语言搜索排名
  • 业务型网站首页百度推广联系人
  • 免费建商城网站哪个好seo和sem的区别与联系
  • 微信公众号免费做影视网站软文范例大全1000字
  • 博物馆网站做的最好的世界杯最新排名
  • wix做的网站aso优化什么意思
  • 政府网站建设电子政务历史权重查询
  • 万能邮箱登录入口合肥优化推广公司
  • wordpress增加百度收录杭州网站seo推广
  • 甘肃肃第八建设集团网站1近期的重大新闻
  • wordpress多站点是什么意思微信小程序开发多少钱
  • 一级a做爰片免费的网站有吗百度推广怎么推广
  • 网站建设好再公安备案长沙官网seo技巧
  • 手机端企业网站怎么做seo管家
  • 猪八戒网站怎么做任务seo查询
  • 做网站找我站长之家网站流量查询
  • wordpress文章选择标签新手seo入门教程
  • 室内设计最好的公司拼多多seo 优化软件
  • 南昌做网站和微信小程序的公司百度平台客服电话
  • 一个网站seo做哪些工作内容全网推广平台
  • phpcms手机网站上海seo网站优化软件
  • 山东网站备案公司吗印度疫情最新消息
  • 郑州外贸网站建设公司排名互联网广告销售
  • 如何管理b2c网站网站在线优化工具