No.2017:Speed Limit

Speed Limit
Time Limit:1000MS  Memory Limit:30000K
Total Submit:2997 Accepted:2094

Description
Bill and Ted are taking a road trip. But the odometer in their car is broken, so they don't know how many miles they have driven. Fortunately, Bill has a working stopwatch, so they can record their speed and the total time they have driven. Unfortunately, their record keeping strategy is a little odd, so they need help computing the total distance driven. You are to write a program to do this computation.

For example, if their log shows

Speed in miles perhour
Total elapsed time in hours
20
2
30
6
10
7

this means they drove 2 hours at 20 miles per hour, then 6-2=4 hours at 30 miles per hour, then 7-6=1 hour at 10 miles per hour. The distance driven is then (2)(20) + (4)(30) + (1)(10) = 40 + 120 + 10 = 170 miles. Note that the total elapsed time is always since the beginning of the trip, not since the previous entry in their log.

 

Input
The input consists of one or more data sets. Each set starts with a line containing an integer n, 1 <= n <= 10, followed by n pairs of values, one pair per line. The first value in a pair, s, is the speed in miles per hour and the second value, t, is the total elapsed time. Both s and t are integers, 1 <= s <= 90 and 1 <= t <= 12. The values for t are always in strictly increasing order. A value of -1 for n signals the end of the input.

Output
For each input set, print the distance driven, followed by a space, followed by the word "miles"

Sample Input

3
20 2
30 6
10 7
2
60 1
30 5
4
15 1
25 2
30 3
10 5
-1

 

Sample Output

170 miles
180 miles
90 miles
Java实现代码:
ExpandedBlockStart.gif ContractedBlock.gif /**/ /*
InBlock.gif * Main.java
InBlock.gif *
InBlock.gif * Created on 2006年9月15日, 上午3:37
InBlock.gif *
InBlock.gif * To change this template, choose Tools | Template Manager
InBlock.gif * and open the template in the editor.
ExpandedBlockEnd.gif 
*/

None.gif
ExpandedBlockStart.gifContractedBlock.gif
/** */ /**
InBlock.gif *
InBlock.gif * 
@author jailu
ExpandedBlockEnd.gif 
*/

None.gif
import  java.util. * ;
ExpandedBlockStart.gifContractedBlock.gif
public   class  Main  dot.gif {
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif    
public static void main(String[] args) dot.gif{
InBlock.gif        Scanner cin 
= new Scanner(System.in);
InBlock.gif        String []strTemp;
InBlock.gif        
int []intSpeed = new int[1];
InBlock.gif        intSpeed[
0= -1;
InBlock.gif        
int []intTime = new int[1];
InBlock.gif        
int i = 0;
InBlock.gif        
int Sum = 0;
InBlock.gif            
InBlock.gif        
while (cin.hasNext())
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            String str 
= cin.nextLine();
InBlock.gif            strTemp 
= str.split(" ");
InBlock.gif            
InBlock.gif            
if (strTemp.length == 1)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
if (intSpeed[0!= -1)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    Sum 
+= intSpeed[0* intTime[0];
InBlock.gif                    
for (int j = 1;j < intSpeed.length;j ++)
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        Sum 
+= intSpeed[j] * (intTime[j] - intTime[j - 1]);
ExpandedSubBlockEnd.gif                    }

InBlock.gif                    System.out.println(Sum 
+ " miles");
InBlock.gif                    Sum 
= 0;
InBlock.gif                    intSpeed[
0= -1;
ExpandedSubBlockEnd.gif                }

InBlock.gif
InBlock.gif                
if (strTemp[0].equals("-1"))
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
break;
ExpandedSubBlockEnd.gif                }

InBlock.gif                
InBlock.gif                intSpeed 
= new int[Integer.parseInt(strTemp[0])];
InBlock.gif                intTime 
= new int[Integer.parseInt(strTemp[0])];
InBlock.gif                i 
= 0;
ExpandedSubBlockEnd.gif            }

InBlock.gif            
else
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                intSpeed[i] 
= Integer.parseInt(strTemp[0]);
InBlock.gif                intTime[i] 
= Integer.parseInt(strTemp[1]);
InBlock.gif                i 
++;
ExpandedSubBlockEnd.gif            }

ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

None.gif


批定结果:
 
 
Run IDUserProblemResultMemoryTimeLanguageCode LengthSubmit Time
1586149jailu2017Accepted1300K281MSJava1.44K2006-09-15 04:29:03.0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Bill and Ted are taking a road trip. But the odometer in their car is broken, so they don't know how many miles they have driven. Fortunately, Bill has a working stopwatch, so they can record their speed and the total time they have driven. Unfortunately, their record keeping strategy is a little odd, so they need help computing the total distance driven. You are to write a program to do this computation. For example, if their log shows Speed in miles perhour Total elapsed time in hours 20 2 30 6 10 7 this means they drove 2 hours at 20 miles per hour, then 6-2=4 hours at 30 miles per hour, then 7-6=1 hour at 10 miles per hour. The distance driven is then (2)(20) + (4)(30) + (1)(10) = 40 + 120 + 10 = 170 miles. Note that the total elapsed time is always since the beginning of the trip, not since the previous entry in their log. Input The input consists of one or more data sets. Each set starts with a line containing an integer n, 1 <= n <= 10, followed by n pairs of values, one pair per line. The first value in a pair, s, is the speed in miles per hour and the second value, t, is the total elapsed time. Both s and t are integers, 1 <= s <= 90 and 1 <= t <= 12. The values for t are always in strictly increasing order. A value of -1 for n signals the end of the input. Output For each input set, print the distance driven, followed by a space, followed by the word "miles" Sample Input 3 20 2 30 6 10 7 2 60 1 30 5 4 15 1 25 2 30 3 10 5 -1 Sample Output 170 miles 180 miles 90 miles

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值