1. 程式人生 > >名企筆試:網易遊戲2017招聘筆試題(趕去公司)

名企筆試:網易遊戲2017招聘筆試題(趕去公司)

網易遊戲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
分析:
我們可以選擇直接到走到公司,也可以直接選則走到某個計程車點,在打車去公司,比較所有過程的最先的時間花費即可。
Code:

#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<math.h>
#include<set>
#include<map>
#include<vector>
using namespace std;
typedef long long LL;

const int MAXN = 105;
struct Point{
    int x;
    int y;
    Point(){}
    Point(int _x,int _y):x(_x),y(_y){}
};
int
Distance(Point p1,Point p2){ return abs(p1.x - p2.x) + abs(p1.y - p2.y); } Point p[MAXN]; int main() { int n,wt,tt,x,y; Point start(0,0),tmp(2,2); while(cin>>n){ for(int i=0;i<n;i++){ cin>>x; p[i].x = x; } for(int i=0;i<n;i++){ cin>>y; p[i].y = y; } cin>>x>>y; Point end(x,y); cin>>wt>>tt; int ans = Distance(start,end) * wt; for(int i=0;i<n;i++){ ans = min(ans, Distance(start,p[i]) * wt + Distance(p[i],end) * tt); } cout<<ans<<endl; } return 0; }