名企筆試:網易遊戲2017招聘筆試題(趕去公司)
阿新 • • 發佈:2018-12-23
網易遊戲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;
}