华为机试题:求车速
2016-01-31 21:27
381 查看
描述: | 一辆以固定速度行驶的汽车,司机在上午10点看到里程表(里程表有6位)上的读数是一个对称数(即这个数从左向右读和从右向左读是完全一样的,例如95859公里)。两小时后里程表上出现了一个新的对称数。问该车的速度(公里/小时)是多少? 接口说明 原型: int CalcSpeedOfCar(int iCurrentMileage, int * piCarSpeed); 输入参数: int pcCurrentMileage:当前里程数(为对称数) (pcCurrentMileage ≤ 999999) 输出参数: int * piCarSpeed:汽车速度 返回值: 0:汽车速度计算成功 1:汽车速度计算失败,在里程表的范围内找不到下一个对称数 |
#include <stdio.h>
#include "OJ.h"
/*
功能: 根据里程计算车速
原型:
int CalcSpeedOfCar(int iCurrentMileage, int * piCarSpeed);
输入参数:
int pcCurrentMileage:当前里程数(为对称数)(pcCurrentMileage ≤ 999999)
返回值:
汽车速度(公里/小时)
*/
int CalcSpeedOfCar(int iCurrentMileage, int * piCarSpeed)
{
/*在这里实现功能*/
if (iCurrentMileage > 999999)
{
return 1;
}
unsigned int i = 0;
for (i = iCurrentMileage + 1; i <= 999999; i++)
{
if (isDuiChenNum(i))
{
*piCarSpeed = (i - iCurrentMileage) / 2;
return 0;
}
}
return 1;
}
/*判断这个数是不是对称数*/
bool isDuiChenNum(const int num)
{
int begin = 0, end = 0;
char str[10] = { 0 };
sprintf_s(str, "%d", num);
end = strlen(str) - 1;
while (begin < end)
{
if (str[begin++] != str[end--])
{
return false;
}
}
return true;
}
相关文章推荐
- Spring AOP两种实现机制是什么?
- 网上商城SSH各个类间的关系(一)
- group by 多个字段
- zoj 2822 Sum of Different Primes (01背包)
- shell脚本编程(四)
- 在android 5.0以上,如何判断当前应用是在前台还是后台
- 第二天ci项目规划 数据库设计
- BZOJ1001狼抓兔子
- Java中的参数传递方式
- 第二天ci项目规划 前后台分离
- 【jQuery基础学习】05 jQuery与Ajax以及序列化
- shell脚本编程(三)
- CentOS7编译安装nginx-1.8.1和编译参数
- Oracle 之 TX锁
- 关于2016的规划
- Zabbix监控系统的搭建
- java Puzzles 之 如何正确的判断奇数
- VMware中linux与window目录共享
- 第二天 ci执行流程
- 《MariaDB必知必会》笔记