B 遇见

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 65536K,其他语言131072K
64bit IO Format: %lld
题目描述
A和B在同一条路上,他们之间的距离为 k 米。A现在想见到B,所以A开车以 x km/h的速度朝着B的方向行驶,同时B也以 y km/h的速度朝着A的方向走去。A的车有 n 个档位,每个档位有不同的速度。现在假设A开车去见B,求他最快和最慢在几秒后能见到B。
输入描述:
一开始一行三个整数 n, m, k ,代表A的车的档位数、B行走的速度和AB之间的距离。
接下来一行 n 个整数,代表A的车的不同档位的行驶速度。
输出描述:
一行两个整数,代表A最快/最慢在几秒后能见到B(向上取整)。
示例1
输入

5 20 80
30 15 10 5 -5
输出

6 20
备注:
对于所有数据,0 <= n <= 1000,-100000 <= A车速度 <= 100000,-A最慢速度 < B行走速度 <= 100000,0 <= k <= 100000.
题目保证最大值和最小值都有解。

签到题:

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 typedef long long ll;
 4 int main() {
 5     ll n;
 6     double m,k,data,minnum=100001,maxnum=-100001;
 7     cin>>n>>m>>k;
 8     k=k*1.0/1000;
 9     for(int i=0;i<n;++i) cin>>data,minnum=min(data,minnum),maxnum=max(data,maxnum);
10     if(n==0) maxnum=minnum=0;
11     double mintime=k*1.0/(maxnum+m);
12     double maxtime=k*1.0/(minnum+m);
13     mintime=mintime*60*60;
14     maxtime=maxtime*60*60;    
15     if(mintime-(int)mintime>1e-6) cout<<((int)mintime)+1<<" ";
16     else cout<<(int)mintime<<" ";
17     if(maxtime-(int)maxtime>1e-6) cout<<((int)maxtime)+1<<endl;
18     else cout<<(int)maxtime<<endl;
19     return 0;
20 }
View Code

相关文章:

  • 2021-12-14
  • 2021-06-18
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-08-03
  • 2021-08-25
  • 2021-08-15
  • 2021-06-08
  • 2021-05-22
  • 2021-12-17
相关资源
相似解决方案