题目:在Excel2003中,用A表示第1列,B表示第2列......Z表示第26列,AA表示第27列,AB表示第28列......以此类推。请写出一个函数,输入用字母表示的列号编码,输出它是第几列。
//这是一道关于进制的题目,其本质是把十进制数字用A~Z表示成二十六进制。#include#include 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;}