[华为机试练习题]40.求车速

题目

描述:  一辆以固定速度行驶的汽车,司机在上午10点看到里程表(里程表有6位)上的读数是一个对称数(即这个数从左向右读和从右向左读是完全一样的,例如95859公里)。两小时后里程表上出现了一个新的对称数。问该车的速度(公里/小时)是多少?

接口说明

原型:

int CalcSpeedOfCar(int iCurrentMileage, int * piCarSpeed);

输入参数:

int pcCurrentMileage:当前里程数(为对称数) (pcCurrentMileage ≤ 999999)

输出参数:

int * piCarSpeed:汽车速度

返回值:

0:汽车速度计算成功

1:汽车速度计算失败,在里程表的范围内找不到下一个对称数

练习阶段: 初级

代码

/*---------------------------------------
*   日期:2015-07-02
*   作者:SJF0115
*   题目:求车速
*   来源:华为机试练习题
-----------------------------------------*/
#include <iostream>
#include "OJ.h"
using namespace std;

// 判断是否是回文数
bool isPlalindrome(int num){
    int tmp = num;
    int newNum = 0;
    while(tmp){
        newNum = newNum * 10 + tmp % 10;
        tmp /= 10;
    }//while
    if(newNum == num){
        return true;
    }//if
    else{
        return false;
    }//else
}

/*
功能: 根据里程计算车速
原型:
    int CalcSpeedOfCar(int iCurrentMileage, int * piCarSpeed);

输入参数:
    int pcCurrentMileage:当前里程数(为对称数)(pcCurrentMileage ≤ 999999)

返回值:
    汽车速度(公里/小时)
*/
int CalcSpeedOfCar(int iCurrentMileage, int * piCarSpeed){
    if(iCurrentMileage <= 0){
        return 1;
    }//if
    bool isFind = false;
    for(int i = iCurrentMileage+1;i <= 999999;++i){
        if(isPlalindrome(i)){
            isFind = true;
            *piCarSpeed = (i - iCurrentMileage) / 2;
            return 0;
        }//if
    }//for
    // 汽车速度计算失败,在里程表的范围内找不到下一个对称数
    if(!isFind){
        return 1;
    }//if
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@SmartSi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值