请设计程序实现如下功能:
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入 :FFFF
样例输出: 65535
#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
long int Convert(const char * str)
{
long int value = 0;
for(int i = 0; i < strlen(str); i++)
{
if(str[i] >= '0' && str[i] <= '9') value = value * 16 + str[i] - '0';
else value = value * 16 + str[i] - 'A' + 10;
}
return value;
}
int Check(const char * str)
{
for(int i = 0; i < strlen(str); i++)
{
if(!((str[i] >= '0' && str[i] <= '9') ||
(str[i] >= 'A' && str[i] <= 'F')))
return 1;
}
return 0;
}
int main()
{
string sInput;
cout<<"请输入一个不超过8位的正的十六进制数字符串:";
cin>>sInput;
if(0 == Check(sInput.c_str())) cout<<"转换后: "<<Convert(sInput.c_str())<<endl;
else cout<<"输入非法,无法转换!"<<endl;
return 0;
}
这里value = value * 16 + str[i] - '0';
类似于把 a*x**3 + b*x**2 + c*x +d 换成d + x(c + x(b + ax)) 减少+或者*运算的总体次数