zoukankan      html  css  js  c++  java
  • 1894. 找到需要补充粉笔的学生编号

    一个班级里有 n 个学生,编号为 0 到 n - 1 。每个学生会依次回答问题,编号为 0 的学生先回答,然后是编号为 1 的学生,以此类推,直到编号为 n - 1 的学生,然后老师会重复这个过程,重新从编号为 0 的学生开始回答问题。

    给你一个长度为 n 且下标从 0 开始的整数数组 chalk 和一个整数 k 。一开始粉笔盒里总共有 k 支粉笔。当编号为 i 的学生回答问题时,他会消耗 chalk[i] 支粉笔。如果剩余粉笔数量 严格小于 chalk[i] ,那么学生 i 需要 补充 粉笔。

    请你返回需要 补充 粉笔的学生 编号 。

     

    示例 1:

    输入:chalk = [5,1,5], k = 22
    输出:0
    解释:学生消耗粉笔情况如下:
    - 编号为 0 的学生使用 5 支粉笔,然后 k = 17 。
    - 编号为 1 的学生使用 1 支粉笔,然后 k = 16 。
    - 编号为 2 的学生使用 5 支粉笔,然后 k = 11 。
    - 编号为 0 的学生使用 5 支粉笔,然后 k = 6 。
    - 编号为 1 的学生使用 1 支粉笔,然后 k = 5 。
    - 编号为 2 的学生使用 5 支粉笔,然后 k = 0 。
    编号为 0 的学生没有足够的粉笔,所以他需要补充粉笔。

    示例 2:

    输入:chalk = [3,4,1,2], k = 25
    输出:1
    解释:学生消耗粉笔情况如下:
    - 编号为 0 的学生使用 3 支粉笔,然后 k = 22 。
    - 编号为 1 的学生使用 4 支粉笔,然后 k = 18 。
    - 编号为 2 的学生使用 1 支粉笔,然后 k = 17 。
    - 编号为 3 的学生使用 2 支粉笔,然后 k = 15 。
    - 编号为 0 的学生使用 3 支粉笔,然后 k = 12 。
    - 编号为 1 的学生使用 4 支粉笔,然后 k = 8 。
    - 编号为 2 的学生使用 1 支粉笔,然后 k = 7 。
    - 编号为 3 的学生使用 2 支粉笔,然后 k = 5 。
    - 编号为 0 的学生使用 3 支粉笔,然后 k = 2 。
    编号为 1 的学生没有足够的粉笔,所以他需要补充粉笔。

     

    提示:

        chalk.length == n
        1 <= n <= 105
        1 <= chalk[i] <= 105
        1 <= k <= 109

    水题一道

    class Solution {
    public:
        int chalkReplacer(vector<int>& chalk, int k) {
            long long total = 0;
            int len = chalk.size();
            for(int i = 0; i < len; i++)
                total += chalk[i];
            k %= total;
            int ret = 0;
            for(int i= 0; i < len; i++)
            {
                if(k < chalk[i])
                {
                    ret = i;
                    break;
                }
                else k -= chalk[i];
            }
            return ret;
        }
    };
    自己选择的路,跪着也要走完。朋友们,虽然这个世界日益浮躁起来,只要能够为了当时纯粹的梦想和感动坚持努力下去,不管其它人怎么样,我们也能够保持自己的本色走下去。
  • 相关阅读:
    paip.禁用IKAnalyzer 的默认词库.仅仅使用自定义词库.
    paip.语义分析分词常见的单音节字词 2_deDuli 单字词 774个
    IFL嵌入式小组技术博客入口导航
    devc++5.0.0.9的调试方法
    getch()、getche()和getchar()之间的区别
    devc++5.0.0.9的调试方法
    声明和定义的区别
    IFL嵌入式小组技术博客入口导航
    C/C++程序到内存分配个人总结
    getch()、getche()和getchar()之间的区别
  • 原文地址:https://www.cnblogs.com/WTSRUVF/p/15780603.html
Copyright © 2011-2022 走看看