• [LeetCode] 157. Read N Characters Given Read4 用Read4来读取N个字符


    Given a file and assume that you can only read the file using a given method read4, implement a method to read n characters.

    Method read4:

    The API read4 reads 4 consecutive characters from the file, then writes those characters into the buffer array buf.

    The return value is the number of actual characters read.

    Note that read4() has its own file pointer, much like FILE *fp in C.

    Definition of read4:

        Parameter:  char[] buf
        Returns:    int
    
    Note: buf[] is destination not source, the results from read4 will be copied to buf[]
    

    Below is a high level example of how read4 works:

    File file("abcdefghijk"); // File is "abcdefghijk", initially file pointer (fp) points to 'a'
    char[] buf = new char[4]; // Create buffer with enough space to store characters
    read4(buf); // read4 returns 4. Now buf = "abcd", fp points to 'e'
    read4(buf); // read4 returns 4. Now buf = "efgh", fp points to 'i'
    read4(buf); // read4 returns 3. Now buf = "ijk", fp points to end of file
    

    Method read:

    By using the read4 method, implement the method read that reads n characters from the file and store it in the buffer array buf. Consider that you cannot manipulate the file directly.

    The return value is the number of actual characters read.

    Definition of read:

        Parameters:	char[] buf, int n
        Returns:	int
    
    Note: buf[] is destination not source, you will need to write the results to buf[]
    

    Example 1:

    Input: file = "abc", n = 4
    Output: 3
    Explanation: After calling your read method, buf should contain "abc". We read a total of 3 characters from the file, so return 3. Note that "abc" is the file's content, not buf. buf is the destination buffer that you will have to write the results to.
    

    Example 2:

    Input: file = "abcde", n = 5
    Output: 5
    Explanation: After calling your read method, buf should contain "abcde". We read a total of 5 characters from the file, so return 5.
    

    Example 3:

    Input: file = "abcdABCD1234", n = 12
    Output: 12
    Explanation: After calling your read method, buf should contain "abcdABCD1234". We read a total of 12 characters from the file, so return 12.
    

    Example 4:

    Input: file = "leetcode", n = 5
    Output: 5
    Explanation: After calling your read method, buf should contain "leetc". We read a total of 5 characters from the file, so return 5.
    

    Note:

    1. Consider that you cannot manipulate the file directly, the file is only accesible for read4 but not for read.
    2. The read function will only be called once for each test case.
    3. You may assume the destination buffer array, buf, is guaranteed to have enough space for storing n characters.

    这道题给了我们一个 Read4 函数,每次可以从一个文件中最多读出4个字符,如果文件中的字符不足4个字符时,返回准确的当前剩余的字符数。现在让实现一个最多能读取n个字符的函数。这题有迭代和递归的两种解法,先来看迭代的方法,思路是每4个读一次,然后把读出的结果判断一下,如果为0的话,说明此时的 buf 已经被读完,跳出循环,直接返回 res 和n之中的较小值。否则一直读入,直到读完n个字符,循环结束,最后再返回 res 和n之中的较小值,参见代码如下:

    解法一:

    // Forward declaration of the read4 API.
    int read4(char *buf);
    
    class Solution {
    public:
        int read(char *buf, int n) {
            int res = 0;
            for (int i = 0; i <= n / 4; ++i) {
                int cur = read4(buf + res);
                if (cur == 0) break;
                res += cur;
            }
            return min(res, n);
        }
    };

    下面来看递归的解法,这个也不难,对 buf 调用 read4 函数,然后判断返回值t,如果返回值t大于等于n,说明此时n不大于4,直接返回n即可,如果此返回值t小于4,直接返回t即可,如果都不是,则直接返回调用递归函数加上4,其中递归函数的 buf 应往后推4个字符,此时n变成n-4即可,参见代码如下:

    解法二:

    // Forward declaration of the read4 API.
    int read4(char *buf);
    
    class Solution {
    public:
        int read(char *buf, int n) {
            int t = read4(buf);
            if (t >= n) return n;
            if (t < 4) return t;
            return 4 + read(&buf[4], n - 4);
        }
    };

    Github 同步地址:

    https://github.com/grandyang/leetcode/issues/157

    类似题目:

    Read N Characters Given Read4 II - Call multiple times

    参考资料:

    https://leetcode.com/problems/read-n-characters-given-read4/

    https://leetcode.com/problems/read-n-characters-given-read4/discuss/49557/Accepted-clean-java-solution

    https://leetcode.com/problems/read-n-characters-given-read4/discuss/49496/Another-accepted-Java-solution

    LeetCode All in One 题目讲解汇总(持续更新中...)

  • 相关阅读:
    【转载】[C#]Log4net中的RollingFileAppender解析
    【转载】大数据量传输时配置WCF的注意事项
    Sql 数据引擎中删除用户名、密码信息
    win10 HTTP 错误 500.21
    SQL Server 将Id相同的字段合并,并且以逗号隔开
    C#中2个日期类型相减
    sql server 查询本年的每个月的数据
    sql server 查询本周、本月所有天数的数据
    sql server中的日期函数
    Sql Server 逻辑文件 '' 不是数据库 '' 的一部分。请使用 RESTORE FILELISTONLY 来列出逻辑文件名。
  • 原文地址:https://www.cnblogs.com/grandyang/p/5174322.html
Copyright © 2020-2023  润新知