zoukankan      html  css  js  c++  java
  • 网易2017算法题-赶去公司

    题目来源自牛客网的网易算法题,如有侵权行为请告知删除。

    题目是这样的:
      终于到周末啦!小易走在市区的街道上准备找朋友聚会,突然服务器发来警报,小易需要立即回公司修复这个紧急bug。假设市区是一个无限大的区域,每条街道假设坐标是(X,Y),小易当前在(0,0)街道,办公室在(gx,gy)街道上。小易周围有多个出租车打车点,小易赶去办公室有两种选择,一种就是走路去公司,另外一种就是走到一个出租车打车点,然后从打车点的位置坐出租车去公司。每次移动到相邻的街道(横向或者纵向)走路将会花费walkTime时间,打车将花费taxiTime时间。小易需要尽快赶到公司去,现在小易想知道他最快需要花费多少时间去公司。

    输入描述:
    输入数据包括五行:
      第一行为周围出租车打车点的个数n(1 ≤ n ≤ 50)
      第二行为每个出租车打车点的横坐标tX[i] (-10000 ≤ tX[i] ≤ 10000)
      第三行为每个出租车打车点的纵坐标tY[i] (-10000 ≤ tY[i] ≤ 10000)
      第四行为办公室坐标gx,gy(-10000 ≤ gx,gy ≤ 10000),以空格分隔
      第五行为走路时间walkTime(1 ≤ walkTime ≤ 1000)和taxiTime(1 ≤ taxiTime ≤ 1000),以空格分隔
    输出描述:
      输出一个整数表示,小易最快能赶到办公室的时间
    输入例子:
      2
      -2 -2
      0 -2
      -4 -2
      15 3
    输出例子:
      42

      由于办公室到小易的距离是固定的,则步行的时间也是固定的,即 wT = ( |gx| + |gy| )walkTime,而坐出租车的时间 = 走到打车点的时间 + 坐出租的时间,即 tT = ( |tX[i]| + |tY[i]| )walkTime + ( |gx-tX[i]| + |gy-tY[i]| )taxiTime;由于出租车打车点有多个,则对每一个出租打车点进行计算,取出最小值与wT进行比较,即可得出最小时间。

    程序如下:

        process.stdin.resume();//回复输入流
        process.stdin.setEncoding('utf8');
    
        var input_stdin = "";//输入的全部数据
        var input_stdin_array = "";//输入的每行数据以数组形式存在
        var input_currentline = 0;//输入的行数
    
        process.stdin.on('data', function (data) {//接收输入的数据
            input_stdin += data;
            if(data.slice(0,-1)==''){
                process.stdin.emit('end');//输入空的回车结束输入
            }
        });
    
        process.stdin.on('end', function () {//end触发
            input_stdin_array = input_stdin.split("
    ");
            main();//对输入进行操作
        });
    
        function readLine() {
            return input_stdin_array[input_currentline++];//读取每一行的数据
        }
        function main() {
            var taxiNum=readLine();
            var tX=readLine().split(' ');
            var tY=readLine().split(' ');
            var gXY=readLine().split(' ');//gXY[0]为gx,gXY[1]为gy
            var time=readLine().split(' ');//time[0]为walkTime,time[1]为taxiTime
        
            var minTime=0;
            var wT=0;
            var tT=(Math.abs(tX[0])+Math.abs(tY[0]))*time[0]+(Math.abs(gXY[0]-tX[0])+Math.abs(gXY[1]-tY[0]))*time[1] ||0;
            wT=(Math.abs(gXY[0])+Math.abs(gXY[1]))*time[0];
            if(taxiNum>1){
                for(var i=1;i<taxiNum;i++){
                    tT=(Math.abs(tX[i])+Math.abs(tY[i]))*time[0]+(Math.abs(gXY[0]-tX[i])+Math.abs(gXY[1]-tY[i]))*time[1]>tT?tT:(Math.abs(tX[i])+Math.abs(tY[i]))*time[0]+(Math.abs(gXY[0]-tX[i])+Math.abs(gXY[1]-tY[i]))*time[1];
                }
            }
            minTime=Math.min(wT,tT);
            console.log(minTime);
        }
    
  • 相关阅读:
    传奇版本自动穿背包中的装备脚本
    MaxM2引擎各种人物触发脚本
    异或加密解密代码
    中元节
    网络加密
    MCMD Commander 命令解释及说明
    Ubuntu字符界面与图形界面切换
    传奇服务端各文件用途说明
    传奇数据库说明
    传奇MAP地图说明
  • 原文地址:https://www.cnblogs.com/aicanxxx/p/6902235.html
Copyright © 2011-2022 走看看