蓝桥杯--- 基础练习 十六进制转十进制 (long long)

问题描述

  从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。(16的8次方=4 294 967 296,要用long long,不仅sum,count也要)count的设计也比较巧妙,count=1  count*=16
  注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。

样例输入

FFFF

样例输出

65535

#include<iostream>
#include<string>
using namespace std;
int main() {
	string s;
	cin>>s;
	long long t=0;
	long long count=1;
	for(int i=s.length()-1; i>=0; i--) {
		if(s[i]-'0'>=0&&s[i]-'0'<=9)
			t=t+(s[i]-'0')*count;
		else
			t=t+(s[i]-'A'+10)*count;
		count*=16;
	}
	printf("%I64d\n",t);
	return 0;
}

猜你喜欢

转载自blog.csdn.net/zhao2chen3/article/details/87816311