24进制转换为10进制

题目:有一个字符串形式表示的24进制数字M,需要转换成10进制数字N,M为无符号数字,可用32位整数存储,以字母0123456789abcdefghijklmn分别表示数字0-23

分析:将24进制数的每一位按照乘以其对应的权值,最后将其加起来

int reverse(string& s)
{
	string table("0123456789abcdefghijklmn");
 
	int sum = 0;
	int x = 0;
	for (int i = s.size() - 1; i >= 0; i--)
	{
		char tmp = s[i];//取出每一位字符
		int pos = table.find(tmp);//找字符对应的数(字符对应的下标就是它所对应的数)
		x = pos * pow(24, s.size() - i - 1);//该位数乘以对应权值
		sum += x;//权值相加
	}
	return sum;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值