HNU[错误的里程表】

文章讲述了小明新买的汽车里程表不显示数字3和8的问题,导致无法正确读取行驶里程。为解决此问题,提出了将显示的数字转换为8进制的方法,因为每次跳跃了两个数,相当于8进制计数。程序通过获取每个数字并根据其位置调整后转换为真实里程。
摘要由CSDN通过智能技术生成

【问题描述】

三月八日,小明买了台新车。但很快小明发现汽车的里程表有问题:里程表上每一位都不显示数字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);
 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值