安排面试城市

简介: 安排面试城市

安排面试城市


640.png


题目描述


今天有N个面试者需要面试,公司安排了两个面试的城市A和B,每一个面试者都有到A城市的开销costA和到B城市的开销costB。公司需要将面试者均分成两拨,使得totalcost最小。说明:题目要求去A的人数和去B的人数相等。


样例:

输入: cost =[[5,4],[3,6],[1,8],[3,9]]

输出: 14

说明: 第一个和第二个人去B城市,剩下的去A城市


思路


贪心原则 每个面试cost 每个面试者去cost 最小的 4+3+1+3 = 11,这个肯定不对 因为要求 A B 是均等的 人数一样。

要求 n/2costA+n/2costB 最小

n/2costA+n/2costB= n/2(costA+CostB)=n/2(CostA+CostA+CostB-CostA)= n*CostA + n/2(CostB-CostA

只要按照CostB-CostA 贪心思想:这个差值从小到大排序即可,取前 N/2 个


示例代码


import java.util.Arrays;
public class MianShi {
    /**
     * 今天有N个面试者需要面试,公司安排了两个面试的城市A和B,每一个面试者都有到A城市的开销costA和到B城市的开销costB。
     * 公司需要将面试者均分成两拨,使得total cost最小。 说明:题目要求去A的人数和去B的人数相等。 样例: 输入: cost =
     * [[5,4],[3,6],[1,8],[3,9]] 输出: 14 说明: 第一个和第二个人去B城市,剩下的去A城市
     */
    //#8月19
    public int mianshi(int[][] cost, int n) {
        int totalcost = 0;
        int[] diff = new int[n];
        /**
         * 贪心原则 每个面试cost 每个面试者去cost 最小的 4+3+1+3 = 11,这个肯定不对 因为要求 A B 是均等的 人数一样。
         * 要求 n/2*costA+n/2*costB 最小 
         * n/2*costA+n/2*costB= n/2(costA+CostB)=n/2(CostA+CostA+CostB-CostA)= n*CostA + n/2(CostB-CostA) 只要 按照
         * CostB-CostA 贪心思想:这个差值从小到大排序即可,取前 N/2 个
         */
        for (int i = 0; i < n; i++) {
            totalcost += cost[i][0];
            diff[i] = cost[i][1] - cost[i][0];
        }
        Arrays.sort(diff);
        for (int j = 0; j < n / 2; j++) {
            totalcost += diff[j];
        }
        return totalcost;
    }
    /**
     * @param args
     */
    public static void main(String[] args) {
        int[][] cost = new int[][]{{5,4},{3,6},{1,8},{3,9}};
        System.out.println(new MianShi().mianshi(cost, 4));
    }
}


相关文章
|
算法 搜索推荐
[leetcode/lintcode 题解] 算法面试真题详解:安排面试城市
[leetcode/lintcode 题解] 算法面试真题详解:安排面试城市
[leetcode/lintcode 题解]  算法面试真题详解:安排面试城市
|
3月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
11天前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
12天前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
38 4
|
1月前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
69 2
|
1月前
|
JSON 安全 前端开发
第二次面试总结 - 宏汉科技 - Java后端开发
本文是作者对宏汉科技Java后端开发岗位的第二次面试总结,面试结果不理想,主要原因是Java基础知识掌握不牢固,文章详细列出了面试中被问到的技术问题及答案,包括字符串相关函数、抽象类与接口的区别、Java创建线程池的方式、回调函数、函数式接口、反射以及Java中的集合等。
28 0
|
3月前
|
Java C++
【Java基础面试十七】、Java为什么是单继承,为什么不能多继承?
这篇文章讨论了Java单继承的设计原因,指出Java不支持多继承主要是为了避免方法名冲突等混淆问题,尽管Java类不能直接继承多个父类,但可以通过接口和继承链实现类似多继承的效果。
【Java基础面试十七】、Java为什么是单继承,为什么不能多继承?
|
3月前
|
存储 安全 Java
这些年背过的面试题——Java基础及面试题篇
本文是技术人面试系列Java基础及面试题篇,面试中关于Java基础及面试题都需要了解哪些内容?一文带你详细了解,欢迎收藏!
|
3月前
|
XML 存储 JSON
【IO面试题 六】、 除了Java自带的序列化之外,你还了解哪些序列化工具?
除了Java自带的序列化,常见的序列化工具还包括JSON(如jackson、gson、fastjson)、Protobuf、Thrift和Avro,各具特点,适用于不同的应用场景和性能需求。
|
3月前
|
Java
【Java基础面试三十七】、说一说Java的异常机制
这篇文章介绍了Java异常机制的三个主要方面:异常处理(使用try、catch、finally语句)、抛出异常(使用throw和throws关键字)、以及异常跟踪栈(异常传播和程序终止时的栈信息输出)。