【问题描述】
三月八日,小明买了台新车。但很快小明发现汽车的里程表有问题:里程表上每一位都不显示数字3和数字8,也就是说直接从数字2跳到数字4,直接从数字7跳到数字9。小明纳闷:这车到底行驶里程是多少。
现在,小明向你求助:根据里程表显示的数字,给出真实的行驶里程。
【输入形式】
输入有多组测试数据。
输入第一行正整数T,表示有多少组测试数据。
后面有T行,每行一个非负整数,表示里程表显示数字,里面不含有数字3和8。该数字不超过10位。
40%的测试数据组数T 10≤T≤ 102;
30%的测试数据组数T 102≤T≤ 103;
20%的测试数据组数T 103≤T≤ 104;
10%的测试数据组数T 104≤T≤ 105;
【输出形式】
对于每组测试数据,输出一个整数占一行:真实的行程里程。
【样例输入】
6
0
1
12
159
111224459
124567976
【样例输出】
0
1
10
103
19212007
21913077
【思路】
关键在于每次都跳了两个数进一位,所以可以化简位8进制数;
在对于数的计算时,要注意在3-8之间减去一个数,大于8减去两个数
(同时注意数据溢出,用long long int)
#include<iostream>
#include<cmath>
using namespace std;
long long int getnum(long long int x)
{ long long int s=x;//一定要加不然数一直在变,比如如果是9则减一为8后就不计算了
if(x>3)s--;
if(x>8)s--;
return s;
}
void transform(int N)
{
for(int i=0;i<N;i++)
{
long long int sum=0;
long long int n=0;
cin>>n;//进行数字的逐个计算
int j=0;
long long int a=0;
while(n)//结束条件为当n!=0时
{
a=n%10;//获得最后一位
sum+=getnum(a)*pow(8,j);
j++;
n=n/10;
}
cout<<sum<<endl;
}
}
int main()
{
int N;
cin>>N;//数据测试
int sum;//得出最后总和
transform(N);
}