168. Excel表列名称
题目描述
给你一个整数 columnNumber
,返回它在 Excel 表中相对应的列名称。
例如:
示例 1:
示例 2:
示例 3:
示例 4:
提示:
- 1 <= columnNumber <= 231 - 1
解题方案
- C
void reverse(char* str) {
int left, right = strlen(str) - 1;
while (left < right) {
char temp = str[left];
str[left] = str[right];
str[right] = temp;
left++;
right--;
}
}
char* convertToTitle(int columnNumber) {
char* str = (char*)malloc(sizeof(char) * 8);
int i = 0;
while (columnNumber > 0) {
int temp = (columnNumber - 1) % 26 + 1;
str[i++] = temp - 1 + 'A';
columnNumber = (columnNumber - temp) / 26;
}
str[i] = '\0';
reverse(str);
return str;
}
171. Excel 表列序号
题目描述
给你一个字符串 columnTitle
,表示 Excel 表格中的列名称。返回 该列名称对应的列序号 。
例如:
示例 1:
示例 2:
示例 3:
提示:
- 1 <= columnTitle.length <= 7
- columnTitle 仅由大写英文组成
- columnTitle 在范围 [“A”, “FXSHRXW”] 内
解题方法
- C 进制转换
int titleToNumber(char* columnTitle) {
int result = 0;
long n = 1;
for (int i = strlen(columnTitle) - 1; i >= 0; i--)
{
int temp = columnTitle[i] - 'A' + 1;
result = result + temp * n;
n = n * 26;
}
return result;
}