zoukankan      html  css  js  c++  java
  • 杭电OJ--自行车计速器

    Biker's Trip Odometer

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 2810    Accepted Submission(s): 1922


    Problem Description
    Most bicycle speedometers work by using a Hall Effect sensor fastened to the front fork of the bicycle. A magnet is attached to one of the spokes on the front wheel so that it will line up with the Hall Effect switch once per revolution of the wheel. The speedometer monitors the sensor to count wheel revolutions. If the diameter of the wheel is known, the distance traveled can be easily be calculated if you know how many revolutions the wheel has made. In addition, if the time it takes to complete the revolutions is known, the average speed can also be calculated. 
    For this problem, you will write a program to determine the total distance traveled (in miles) and the average speed (in Miles Per Hour) given the wheel diameter, the number of revolutions and the total time of the trip. You can assume that the front wheel never leaves the ground, and there is no slipping or skidding.
     


     

    Input
    Input consists of multiple datasets, one per line, of the form:

    diameter revolutions time

    The diameter is expressed in inches as a floating point value. The revolutions is an integer value. The time is expressed in seconds as a floating point value. Input ends when the value of revolutions is 0 (zero).
     


     

    Output
    For each data set, print:

    Trip #N: distance MPH

    Of course N should be replaced by the data set number, distance by the total distance in miles (accurate to 2 decimal places) and MPH by the speed in miles per hour (accurate to 2 decimal places). Your program should not generate any output for the ending case when revolutions is 0.

    Constants

    For p use the value: 3.1415927.
    There are 5280 feet in a mile.
    There are 12 inches in a foot.
    There are 60 minutes in an hour.
    There are 60 seconds in a minute.
    There are 201.168 meters in a furlong.
     


     

    Sample Input
    26 1000 5 27.25 873234 3000 26 0 1000
     


     

    Sample Output
    Trip #1: 1.29 928.20 Trip #2: 1179.86 1415.84
     


     

    Source
    Greater New York 2003
     1 #include <stdio.h>  
     2 #define P 3.1415927  
     3 #define toFeet(x) x/12.0  
     4 #define toMiles(x) x/5280.0  
     5   
     6 int main(){  
     7     double diameter;//直径  
     8     int revolutions;//转数  
     9     double time;//时间  
    10     double s;  //距离 
    11     int count=1;  
    12     while(scanf("%lf%d%lf",&diameter,&revolutions,&time),revolutions){  
    13         time/=3600;  
    14         diameter/=63360;  
    15         s=diameter*P*revolutions;  
    16         printf("Trip #%d: %.2lf %.2lf
    ",count++,s,s/time);  
    17     }  
    18 }
  • 相关阅读:
    DES 加密算法
    socket编程之bind()函数
    如何启动ubuntu下的telnet服务
    基于duilib修改的版本上传了
    mmsPlayer, for android ,wince,windows,wm等
    [转]log4c 配置文件的用法
    mmsPlayer, for android ,wince,windows,wm等
    wince 版本的播放器 是基于 TC89系列
    cocos2dx做的一个圣诞节软件
    基于duilib修改的版本上传了
  • 原文地址:https://www.cnblogs.com/MICE1024/p/5684299.html
Copyright © 2011-2022 走看看