Excel表列名称

给你一个整数 columnNumber ,返回它在 Excel 表中相对应的列名称。

例如:

复制代码
A -> 1
B -> 2
C -> 3
...
Z -> 26
AA -> 27
AB -> 28 
...

示例 1:

复制代码
输入:columnNumber = 1
输出:"A"

示例 2:

复制代码
输入:columnNumber = 28
输出:"AB"

示例 3:

复制代码
输入:columnNumber = 701
输出:"ZY"

示例 4:

复制代码
输入:columnNumber = 2147483647
输出:"FXSHRXW"

思路:定义两个全局变量数组,将输入的数对26进行整除和取余操作,从低到高存在数组1中,数组2反向装入数组1的内容。

复制代码
#include <stdio.h>

char g_ret[8];
char g_ret1[8];

char * convertToTitle(int columnNumber){
    int n=columnNumber;
    int k,j=0,i=0;
    while(n>0)//当输入值大于0时
    {
        k=n%26;//除26取余数
        n=n/26;//除26取整
        if(k==0)//当n能被26整除时
        {         
            k=26;    //k=26     
            n--;     //n减1    
        }
        g_ret[i++]='A'+k-1;//当k能被26整除时g_ret最高位为'Z',即'A'+26-1;当k不能被26整除时,g_ret等于'A'+某个小于25的值
    }
    g_ret[i]='\0';//最后一位为截至符
    i=i-1;//从倒数第二位开始
    while(i>=0)
    {
        g_ret1[j++]=g_ret[i];//将g_ret中最高位赋值给g_ret1中最低位
        i--;
    }
    g_ret1[j]='\0';
    //char *p = g_ret1;
    //return p;
}

int main()
{

    int columnNumber = 252;
    convertToTitle(columnNumber);
    printf("%s\n",g_ret1);//直接打印全局变量


    return 0;
}
相关推荐
青梅橘子皮6 小时前
Linux---基本指令
linux·运维·服务器
ZC跨境爬虫6 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人6 小时前
HTML 字符引用完全指南
开发语言·前端·html
REDcker6 小时前
Linux信号机制详解 POSIX语义与内核要点 sigaction与备用栈实践
linux·运维·php
幼儿园技术家6 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
cui_ruicheng7 小时前
Linux进程间通信(三):System V IPC与共享内存
linux·运维·服务器
蚰蜒螟8 小时前
深入 Linux 内核同步机制:从 futex 到 spinlock 的完整旅程
linux·windows·microsoft
运维全栈笔记8 小时前
Linux安装配置Tomcat保姆级教程:从部署到性能调优
linux·服务器·中间件·tomcat·apache·web
前端摸鱼匠8 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker8 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js