2023小米秋招真题-手机流畅运行的秘密

2023小米秋招真题-手机流畅运行的秘密

这是一道小米面试题,使用贪心的思想

8月份发布会一结束,米小兔就在公司领到了一台最新发布的XiaomiMX Fold3手机。这是一款小米舰折屏手机,并搭载了全新升级架构的MIU114系统。其先进的应用引擎不仅让系统更流畅,应用体验也大幅提升。在一个优化项中,为了尽可能提升用户白天使用手机的体验和续航,某些已经在系统中注册过的任务会被设置为空闲任务,仅在手机空闲时运行(比如数据备份或AI相册整理)。现在系统中注册了若干组空闲任务,每个任务有各自的耗电量以及允许任务运行的最低初始电量,我们需要计算手机能够串行完成全部任务的最低初始电量。
注意点1 :所有电量以mAh(至安时)计,XaomiMX Fold3的大电池容量是4800mAh

**注意点2:**本题目假设手机在运行空闲任务期间,不处于充电状态,也没有额外耗电行为

注意点3:智能应用引擎会以最合适的顺序执行运行任务

输入描述

个猫述了所有任务的长字符串。任务与任务必间用逗号隔开,每组任务由耗电量及最低初始电量组成,用冒号隔

开。

输出描述

一个数字,代表依次完成全部任务的最低初始电量,如果最低初始电量超过手机电池容量,则返回-1

复制代码
// 样例输入
1:10,2:12,3:10

// 13

分析

每个任务有允许任务运行的最低初始电量,按照第一眼的想法可能会按照任务的最低初始电量递减排序去贪心。但是这样是不对的,举个例子

有两个任务,任务 1 耗电量是 cost1,允许任务运行的最低电量是 least1。任务 2 的耗电量和最低电量是 cost2least2。当前电量为 currentBattery,假设 cost1>currentBattery-least2cost2<=currentBattery-least1这两个式子是可以同时存在的

假如任务 1 的最低电量 > 任务 2 的最低电量,按照我们刚才贪心方法,优先执行最低电量高的任务,也就是先执行任务 1,任务 1 执行完后剩余电量为 currentBattery-cost1,根据 cost1>currentBattery-least2 可知 currentBattery-cost1 < least2 因此不能执行任务 2

而假如这时我们先执行任务 2 呢(最低电量低的任务 ),执行任务 2 后剩余电量为 currentBattery-cost2,根据 cost2<=currentBattery-least1 可知 currentBattery-cost2 >= least1 这时是可以接着运行任务 1的

以上分析证明了按照任务最低初始电量递减排序去贪心是不对的

那么该如何贪心呢?同样有任务 1 和 任务 2

  • 先执行任务 1,再执行任务 2,如果两个任务都能执行即 currentBattery-cost1>least2,那么 currentBattery 必须满足 currentBattery > cost1+least2
  • 先执行任务 2,再执行任务 1,如果两个任务都能执行即 currentBattery-cost2>least1,那么 currentBattery 必须满足 currentBattery > cost2+least1

题目要求初始电量最小,因此,就得取 cost1+least2cost2 +least1 两者的较小值 ,两边同减去 least1 和 least2,左边变成 cost1-least1,右边变成 cost2-least2,因此,如果 cost1-least1 较小就先执行任务 1,否则先执行任务 2。按照 cost-least 升序排序去贪心即可

最终代码展示

java 复制代码
package Y20222;

import java.util.*;

// 1:10,2:12,3:10
// 1:10,2:12,10:3
// 3:1,3:1,3:1
public class A {

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String str = scan.next();
        String[] strings = str.split(",");

        int n = strings.length;

        int[][] arr = new int[n][2];

        for(int i = 0;i < n;i ++) {
            String[] strings1 = strings[i].split(":");
            arr[i][0] = Integer.valueOf(strings1[0]);
            arr[i][1] = Integer.valueOf(strings1[1]);
        }

        Arrays.sort(arr,(a,b)-> a[0]-a[1]-(b[0]-b[1]));

        int ans = 0;
        int preCost = 0;
        for(int i = 0;i < n;i ++) {
            ans = Math.max(ans, preCost+Math.max(arr[i][0],arr[i][1]));
            preCost += arr[i][0];
        }

        System.out.println(ans <= 4800?ans:-1);
        scan.close();
    }


}
相关推荐
互联网全栈架构40 分钟前
遨游Spring AI:第一盘菜Hello World
java·人工智能·后端·spring
qq_4298796741 分钟前
省略号和可变参数模板
开发语言·c++·算法
优秀的颜2 小时前
计算机基础知识(第五篇)
java·开发语言·分布式
BillKu2 小时前
Java严格模式withResolverStyle解析日期错误及解决方案
java
飞川撸码2 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
网安INF2 小时前
ElGamal加密算法:离散对数难题的安全基石
java·网络安全·密码学
Neil今天也要学习2 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910133 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
AWS官方合作商3 小时前
在CSDN发布AWS Proton解决方案:实现云原生应用的标准化部署
java·云原生·aws
亮亮爱刷题3 小时前
算法练习-回溯
算法