[华为机试练习题]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;
}
时间: 2024-11-08 21:57:09

[华为机试练习题]40.求车速的相关文章

[华为机试练习题]50.求M的N次方的最后三位

题目 描述: 正整数M 的N次方有可能是一个非常大的数字,我们只求该数字的最后三位 例1: 比如输入5和3 ,5的3次方为125,则输出为125 例2: 比如输入2和10 2的10次方为1024 ,则输出结果为24 例3: 比如输入111和5 111的5次方为116850581551,则输出结果为551 练习阶段: 初级 代码 /*--------------------------------------- * 日期:2015-07-04 * 作者:SJF0115 * 题目:求M的N次方的最后

[华为机试练习题]56.求子数组的最大和

题目 描述: 输入一个整形数组.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值. 接口 Int GetSubArraySum(Int* pIntArray,Int nCount): 规格 要求时间复杂度为O(n) 举例 例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4, 7, 2, 因此输出为该子数组的和18 练习阶段: 初级 代码 /*-------------------------------

[华为机试练习题]42.求二叉树的深度和宽度

题目 题目标题: 求二叉树的宽度和深度 给定一个二叉树,获取该二叉树的宽度和深度. 例如输入 a / \ b c / \ / \ d e f g 返回3. 接口说明 原型: int GetBiNodeInfo(BiNode &head, unsigned int *pulWidth, unsigned int *pulHeight) 输入参数: head 需要获取深度的二叉树头结点 输出参数(指针指向的内存区域保证有效): pulWidth 宽度 pulHeight 高度 返回值: 0 成功 1

[华为机试练习题]45.求某二进制数中1的个数

题目 描述: 题目标题: 求某二进制数中1的个数. 给定一个unsigned int型的正整数,求其二进制表示中"1"的个数,要求算法的执行效率尽可能地高. 详细描述: 原型: int GetCount(unsigned int num) 输入参数: num 给定的正整数 输出参数(指针指向的内存区域保证有效): 无 返回值: 返回1的个数 举例: 输入13,则对应的二进制是1101,那么1的个数为3个.则:返回3. 练习阶段: 初级 代码 /*--------------------

[华为机试练习题]47.整型反序

题目 描述: 简要描述:给出一个不多于5位的整数, 进行反序处理 要求: 1.求出它是几位数 2.分别输出每一位数字 3.按逆序输出各位数字,例如原数为321,应输出123(仅数字间以空格间隔, 负号与数字之间不需要间隔) 例如: 输入: 12345 输出: 5 1 2 3 4 5 54321 注意:如果是负数,负号加在第一个数字之前, 与数字没有空格间隔 比如 输入: -12345 输出: 5 -1 2 3 4 5 -54321 函数原型: /* 输入: iInput: 位数不大于5的整数 输

[华为机试练习题]51.数列求和

题目 描述: 题目描述 编写程序,输入一个正整数n,求下列算式的值.要求定义和调用函数fact(k)计算k的阶乘. 1+1/2!+ .... +1/n! 计算结果保存在double类型变量中. 接口说明 原型: void GetResult(int InputNum, double *NumResult); 输入参数: Int InputNum:输入一个正整数,进行表达式计算 char *NumResult:输出表达式的值 返回值: void 练习阶段: 初级 代码 /*------------

[华为机试练习题]48.阿姆斯特朗数

题目 描述: 如果一个正整数等于其各个数字的立方和,则该数称为阿姆斯特朗数(亦称为自恋性数),1除外,如407 = 43+03+73就是一个阿姆斯特朗数.试编程求n(n ≤ 65536)以内的所有阿姆斯特朗数. 接口说明 原型: int CalcArmstrongNumber(int n); 输入参数: int n: n ≤ 65536 返回值: n以内的阿姆斯特朗数的数量 练习阶段: 初级 代码 /*--------------------------------------- * 日期:20

[华为机试练习题]32.数字基root

题目 描述: 求整数的Root:给定正整数,求每位数字之和;如果和不是一位数,则重复; 题目类别: 数组 难度: 初级 运行时间限制: 10Sec 内存限制: 128MByte 阶段: 入职前练习 输入: 输入任意一个或多个整数 输出: 输出各位数字之和,直到和为个位数为止(输入异常,则返回-1) 多行,每行对应一个输入数据的结果. 样例输入: 25 865 样例输出: 7 1 代码 /*--------------------------------------- * 日期:2015-07-0

[华为机试练习题]60.水仙花数

题目 描述: 水仙花数又称阿姆斯特朗数. 水仙花数是指一个n 位数( n≥3 ),它的每个位上的数字的n 次幂之和等于它本身.(例如:1^3 + 5^3 + 3^3 = 153) 求输入的数字是否为水仙花数 练习阶段: 初级 代码 /*--------------------------------------- * 日期:2015-07-05 * 作者:SJF0115 * 题目:水仙花数 * 来源:华为机试练习题 ----------------------------------------