题目:在Excel2003中,用A表示第1列,B表示第2列......Z表示第26列,AA表示第27列,AB表示第28列......以此类推。请写出一个函数,输入用字母表示的列号编码,输出它是第几列。
//这是一道关于进制的题目,其本质是把十进制数字用A~Z表示成二十六进制。
#include<iostream>
#include<string>
using namespace std;
int StringToInt(const string& str)
{
int length = str.length();
if (length < 0)
{
cout << "无效输入" << endl;
return -1;
}
int sum = 0; //如果输入的字符为空字符,输出为0。
for (int i = 0; i < str.length(); i++)
{
int value = str[i] - 'A';
if (value >= 26 || value < 0)
{
cout << "无效输入" << endl;
}
sum = 26 * sum + value + 1;
}
return sum;
}
int main()
{
string str;
//while (getline(cin, str))
cin >> str;
cout << StringToInt(str) << endl;
return 0;
}