【问题描述】
三月八日,小明买了台新车。但很快小明发现汽车的里程表有问题:里程表上每一位都不显示数字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
【思路】
用八进制捏~
【AC代码】
//十位数 因此要用long int!!!!!!!!!!!
#include<iostream>
#include<cmath>
using namespace std;
int main (){
int T;
cin>>T;
while(T--)
{
long int a;
cin>>a;
if(a==0) {
cout<<0<<'\n';
}
else
{
int wei=log10(a)+1; //取位数 每位上的相加
long int result=0;
while(wei){
long int temp=pow(10,wei-1);
int p=a/temp;
a=a%temp;
if(p>=9){
p-=2;
}
else if(p>=4)
{p--;}
result=result+p*pow(8,wei-1);
wei--;
}
cout<<result<<'\n';
}
}
}
【写在后面】
对你有帮助记得点个赞哦~有啥问题请留言~