2022-06-07:牛牛今年上幼儿园了,老师叫他学习减法, 老师给了他5个数字,他每次操作可以选择其中的4个数字减1, 减一之后的数字不能小于0,因为幼儿园的牛牛还没有接触过负数。 现在牛牛想知道,

Posted 福大大架构师每日一题

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2022-06-07:牛牛今年上幼儿园了,老师叫他学习减法, 老师给了他5个数字,他每次操作可以选择其中的4个数字减1, 减一之后的数字不能小于0,因为幼儿园的牛牛还没有接触过负数。 现在牛牛想知道,相关的知识,希望对你有一定的参考价值。

2022-06-07:牛牛今年上幼儿园了,老师叫他学习减法,
老师给了他5个数字,他每次操作可以选择其中的4个数字减1,
减一之后的数字不能小于0,因为幼儿园的牛牛还没有接触过负数。
现在牛牛想知道,自己最多可以进行多少次这样的操作。
扩展问题来自leetcode 2141,掌握了这个题原始问题就非常简单了。
来自阿里笔试。

答案2022-06-07:

【前缀和】数组,二分答案法。

代码用rust编写。代码如下:

fn main() 
    let mut arr: Vec<isize> = vec![1, 2, 3, 4, 5];
    let n = 5;
    let ans = max_run_time(n, &mut arr);
    println!("ans = ", ans);


fn max_run_time(n: isize, arr: &mut Vec<isize>) -> isize 
    arr.sort();
    let size = arr.len() as isize;
    let mut sums: Vec<isize> = vec![];
    for _ in 0..size 
        sums.push(0);
    
    sums[0] = arr[0];
    for i in 1..size 
        sums[i as usize] = sums[(i - 1) as usize] + arr[i as usize];
    
    let mut l: isize = 0;
    let mut m = 0;
    let mut r = sums[(size - 1) as usize] / n;
    let mut ans = -1;
    while l <= r 
        m = (l + r) / 2;
        if ok(arr, &mut sums, m, n) 
            ans = m;
            l = m + 1;
         else 
            r = m - 1;
        
    
    return ans;


fn ok(arr: &mut Vec<isize>, sum: &mut Vec<isize>, time: isize, mut num: isize) -> bool 
    let mut l: isize = 0;
    let mut m = 0;
    let mut r = arr.len() as isize - 1;
    let mut left = arr.len() as isize;
    // >= time 最左
    while l <= r 
        m = (l + r) / 2;
        if arr[m as usize] >= time 
            left = m;
            r = m - 1;
         else 
            l = m + 1;
        
    
    num -= arr.len() as isize - left;
    let rest = if left == 0 
        0
     else 
        sum[(left - 1) as usize]
    ;
    return time * num <= rest;


执行结果如下:


左神java代码

开发者涨薪指南 48位大咖的思考法则、工作方式、逻辑体系

以上是关于2022-06-07:牛牛今年上幼儿园了,老师叫他学习减法, 老师给了他5个数字,他每次操作可以选择其中的4个数字减1, 减一之后的数字不能小于0,因为幼儿园的牛牛还没有接触过负数。 现在牛牛想知道,的主要内容,如果未能解决你的问题,请参考以下文章

郭老师神题(幼儿园数学)

13岁学生厌学心理压力人际关系问题调整成功案例

幼儿园助教活动感想

王海英教授:幼儿园一日生活中的深度学习

王海英:幼儿园一日生活中的深度学习 | 幼视野

读 邹欣老师大学师生关系 有感