【蓝桥杯】43688-《Excel地址问题》
Excel地址问题
题目描述
Excel 单元格的地址表示很有趣,它可以使用字母来表示列号。比如,
A 表示第 1 列,
B 表示第 2 列,
…
Z 表示第 26 列,
AA 表示第 27 列,
AB 表示第 28 列,
…
BA 表示第 53 列,
⋯
⋯
当然 Excel 的最大列号是有限度的,所以转换起来并不难。
如果我们想把这种表示法一般化,就可以把很大的数字转换为一个较长的字母序列。
本题目即是要求对输入的数字, 输出其对应的 Excel 地址表示方式。
输入描述
输入一个整数 n,其范围 [1,2147483647]。
输出描述
输出 n 所对应的 Excel 地址表示方式。
输入输出样例
示例
输入
26
输出
Z
解题思路
这个题目要求我们将一个整数转换成 Excel 的列地址表示方式。在 Excel 中,列地址是由 A-Z 的 26 个英文字母组成的序列,其中 A 表示第 1 列,Z 表示第 26 列,AA 表示第 27 列,AB 表示第 28 列,以此类推。
为了将整数转换为 Excel 列地址,我们可以使用以下步骤:
- 初始化变量: 创建一个空字符串 excel_addr,用于存储最终的 Excel 列地址。
- 循环处理: 当输入的整数 n 大于 0时,执行以下循环:
首先,将 n 减 1,因为在 Excel 列地址中,A 对应的是 1,而不是 0。
然后,将 n 对 26取余,得到一个 0-25 的数字,这个数字对应 A-Z 中的一个字母。 使用 chr 函数和 ord函数将这个数字转换为对应的字母,并将其添加到 excel_addr 的开头。
最后,将 n 除以26,向下取整,以便在下一轮循环中处理更高位的数字。 - 返回结果: 当循环结束后,excel_addr 中存储的就是输入整数对应的Excel 列地址,将其输出即可。
这个算法的时间复杂度是 O (log n),其中 n 是输入的整数。这是因为每次循环 n 都会被除以 26,所以循环次数大约是 log26 (n)。
代码实现
Python 实现
def num_to_excel(n):"""将整数转换为 Excel 列地址表示方式。参数:n (int): 输入的整数,范围 [1, 2147483647]。返回:str: 对应的 Excel 列地址表示方式。"""# 初始化一个空字符串,用于存储最终的 Excel 列地址excel_addr = "" while n > 0:# 在 Excel 列地址中,A 对应的是 1,而不是 0,所以需要减 1n -= 1 # 将 n 对 26 取余得到一个 0-25 的数字,转换为对应的字母,并添加到 excel_addr 的开头excel_addr = chr(ord('A') + (n % 26)) + excel_addr # 将 n 除以 26,向下取整,以便在下一轮循环中处理更高位的数字n //= 26 return excel_addrdef main():"""主函数,读取用户输入,调用 num_to_excel 函数,并输出结果。"""# 读取用户输入的整数n = int(input()) # 调用 num_to_excel 函数,并输出结果print(num_to_excel(n)) if __name__ == "__main__":main()
JAVA 实现
import java.util.Scanner;
public class ExcelColumnName {// 实现将数字转换为Excel列名样式的方法,功能类似Python中的num_to_excel函数public static String numToExcel(int n) {StringBuilder excelAddr = new StringBuilder();while (n > 0) {n--;// 计算当前位置对应的字符char ch = (char) ('A' + (n % 26));excelAddr.insert(0, ch);n /= 26;}return excelAddr.toString();}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();System.out.println(numToExcel(n));scanner.close();}
}
C++ 实现
#include <iostream>
#include <string>
using namespace std;string numToExcel(int n) {string excelAddr = "";while (n > 0) {n--;char ch = 'A' + (n % 26);excelAddr = char(ch) + excelAddr;n /= 26;}return excelAddr;
}int main() {int n;cin >> n;cout << numToExcel(n) << endl;return 0;
}
C 实现
#include <stdio.h>
#include <stdlib.h>
#include <string.h>// 函数用于将数字转换为类似Excel列名的字符串表示
void numToExcel(int n, char *result) {int index = 0;while (n > 0) {n--;result[index++] = 'A' + (n % 26);n /= 26;}result[index] = '\0';// 反转字符串,因为之前是从后往前构建字符的,现在要调整顺序int start = 0;int end = index - 1;while (start < end) {char temp = result[start];result[start] = result[end];result[end] = temp;start++;end--;}
}int main() {int n;scanf("%d", &n);char *excelAddr = (char *)malloc((n > 0? 10 : 1) * sizeof(char)); // 简单预估下足够长的空间,可按需优化长度计算if (excelAddr == NULL) {printf("内存分配失败\n");return 1;}numToExcel(n, excelAddr);printf("%s\n", excelAddr);free(excelAddr);return 0;
}
程序验证
输入
26
输出
Z
输入
66
输出
BN

相关文章:
【蓝桥杯】43688-《Excel地址问题》
Excel地址问题 题目描述 Excel 单元格的地址表示很有趣,它可以使用字母来表示列号。比如, A 表示第 1 列, B 表示第 2 列, … Z 表示第 26 列, AA 表示第 27 列, AB 表示第 28 列, … BA 表示…...
【bodgeito】攻防实战记录
也许有一天我们再相逢,睁开眼睛看清楚,我才是英雄。 进入网站整体浏览网页 点击页面评分进入关卡 一般搭建之后这里都是红色的,黄色是代表接近,绿色代表过关 首先来到搜索处本着见框就插的原则 构造payload输入 <script>…...
Soul Preserver
Soul Preserver 护魂者 Soul Preserver - Item - 魔兽世界怀旧服WLK3.35数据库_巫妖王之怒80级魔兽数据库_wlk数据库 原来的1274法力值 圣光闪现不需要法力 圣光术原来的474法力值 但是测试数据3-5分钟有时候就触发了3次,节约2400蓝...
Android 折叠屏问题解决 - 展开或收起页面重建
一、问题说明 Android 折叠屏展开或收起后页面会重建,并重新走 onCreate onStart onResume ... 重新创建后页面的状态也会丢失,比如页面中是一个 RecyclerView,我们滑动到了第 5 个卡片的位置,展开后又自动滑动到了第 1 个卡片的…...
深入理解 Linux wc 命令
文章目录 深入理解 Linux wc 命令1. 基本功能2. 常用选项3. 示例3.1 统计文件的行、单词和字符数3.2 仅统计行数3.3 统计多个文件的总和3.4 使用管道统计命令输出的行数 4. 实用案例4.1 日志分析4.2 快速统计代码行数4.3 统计单词频率 5. 注意事项6. 总结 深入理解 Linux wc 命…...
半连接转内连接规则的原理与代码解析 |OceanBase查询优化
背景 在查询语句中,若涉及半连接(semi join)操作,由于半连接不满足交换律的规则,连接操作必须遵循语句中定义的顺序执行,从而限制了优化器根据参与连接的表的实际数据量来灵活选择优化策略的能力。为此&am…...
多进程、多线程、分布式测试支持-pytest-xdis插件
pytest-xdist是pytest测试框架的一个插件,它提供了多进程、多线程和分布式测试的支持,可以显著提高测试效率。以下是对pytest-xdist的详细介绍: 一、安装 要使用pytest-xdist,首先需要安装pytest和pytest-xdist。可以通过pip进行…...
Oracle virTualBox安装window10
一、下载windows10镜像 我下载的windows10镜像如下: 内部文件如下: 二、错误的安装方法 直接新建虚拟机,选择镜像文件: 启动虚拟机(会一直提示没有启动设备,选择镜像后一直弹窗提示) 三、正确…...
Python7-数据结构
记录python学习,直到学会基本的爬虫,使用python搭建接口自动化测试就算学会了,在进阶webui自动化,app自动化 python基础7-数据结构的那些事儿 常见的数据结构有哪些?线性数据结构有哪些?非线性数据结构有哪…...
springboot指定ssl版本连接
在application.yml配置指定 server.ssl.protocolTLSv1.2结果应用依然接受低版本如TLSv1.0的连接 可以在ie浏览器:设置-Internet选项-高级,将当前连接改为TLSv1.0进行测试 这种情况可以通过增加配置仅由TLSv1.2支持的密码处理: server.ssl.…...
VTK编程指南<十二>:VTK图像数据结构及图像创建与显示
数字图像是一种重要的多媒体数据,广泛应用于工业生产、生物医学、地质、气象等重要领域。数字图像处理技术具有重要的应用价值。图像是VTK里非常重要的一种数据结构。本章重点讲解VTK在数字图像处理应用方面的相关技术。 1、VTK图像数据结构 数字图像文件内容由两个…...
EasyGBS国标GB28181平台P2P远程访问故障排查指南:客户端角度的排查思路
在现代视频监控系统中,P2P(点对点)技术因其便捷性和高效性而被广泛应用。然而,当用户在使用P2P远程访问时遇到设备不在线或无法访问的问题时,有效的排查方法显得尤为重要。本文将从客户端的角度出发,详细探…...
打造智慧医院挂号枢纽:SSM 与 Vue 融合的系统设计与实施
2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统,它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等,非常…...
网络编程 02:IP 地址,IP 地址的作用、分类,通过 Java 实现 IP 地址的信息获取
一、概述 记录时间 [2024-12-18] 前置文章:网络编程 01:计算机网络概述,网络的作用,网络通信的要素,以及网络通信协议与分层模型 本文讲述网络编程相关知识——IP 地址,包括 IP 地址的作用、分类ÿ…...
如何使用Python WebDriver爬取ChatGPT内容(完整教程)
大背景 虽然我们能用网页版chatGPT来聊天、写文章,但是我们采集大量的内容,就得不断地手动输入提问来获取答案,并且将结果复制到数据库来保存。如果整个过程能使用程序来做自然要节省很多的人力,精力和时间。 Python webdirver …...
WSL切换默认发行版
查看适用于wsl的子系统有哪些: wslconfig /list 设置wsl的默认发行版 wslconfig /setdefault Ubuntu-20.04...
全志H618 Android12修改doucmentsui功能菜单项
背景: 由于当前的文件管理器在我们的产品定义当中,某些界面有改动的需求,所以需要在Android12 rom中进行定制以符合当前产品定义。 需求: 在进入File文件管理器后,查看...功能菜单时,有不需要的功能菜单,需要隐藏,如:新建窗口、不显示的文件夹、故代码分析以及客制…...
移动网络(2,3,4,5G)设备TCP通讯调试方法
背景: 当设备是移动网络设备连接云平台的时候,如果服务器没有收到网络数据,移动物联设备发送不知道有没有有丢失数据的时候,需要一个抓取设备出来的数据和服务器下发的数据的方法。 1.服务器系统是很成熟的,一般是linu…...
网络安全概论——入侵检测系统IDS
一、入侵检测的概念 1、入侵检测的概念 检测对计算机系统的非授权访问对系统的运行状态进行监视,发现各种攻击企图、攻击行为或攻击结果,以保证系统资源的保密性、完整性和可用性识别针对计算机系统和网络系统或广义上的信息系统的非法攻击,…...
Linux通信System V:消息队列 信号量
Linux通信System V:消息队列 & 信号量 一、信号量概念二、信号量意义三、操作系统如何管理ipc资源(2.36版本)四、如何对信号量资源进行管理 一、信号量概念 信号量本质上就是计数器,用来保护共享资源。多个进程在进行通信时&a…...
2.2.2.2 使用Spark单机版环境
本次实战深入探索Spark单机版环境的核心功能。首先运行SparkPi示例程序计算圆周率,验证集群计算能力;随后启动spark-shell进入交互式环境,完成等差数列求和、九九乘法表打印等基础任务。重点通过Scala代码操作RDD,演示了从文本文件…...
Phi-4-mini-reasoning逻辑推理效果展示:图灵测试级数学对话与错误自检能力
Phi-4-mini-reasoning逻辑推理效果展示:图灵测试级数学对话与错误自检能力 1. 模型简介 Phi-4-mini-reasoning 是一个基于合成数据构建的轻量级开源模型,专注于高质量、密集推理的数据处理。作为Phi-4模型家族的一员,它经过专门微调以提升数…...
OpenClaw替代方案:当Qwen3-4B不可用时降级策略
OpenClaw替代方案:当Qwen3-4B不可用时降级策略 1. 为什么需要降级策略 上周三凌晨3点,我的OpenClaw自动化脚本突然停止了工作。原本定时执行的周报生成任务卡在了模型调用环节——Qwen3-4B服务因网络波动暂时不可用。这次意外让我意识到:依…...
自抗扰控制三阶LADRC在三相LCL逆变器模型中的应用:图一至图三分析
自抗扰控制三阶LADRC控制三相LCL逆变器模型 图一:d轴参考电流在0.15从40变到80的并网电压电流波形 图二:三阶LADRC结构控制LCL三阶模型 图三:整体结构图 参考文献:基于抗扰控制三相LCL逆变器控制策略研究 光伏并网逆变器最头疼的就是LCL滤波器引发的震荡问题。这玩意儿参数敏感…...
FastAPI ORM 封装:FastAPI 与 SQLModel 的无缝集成与快速开发
更多内容请见: 《Python Web项目集锦》 - 专栏介绍和目录 核心价值: SQLModel 是 FastAPI 作者 Tiangolo 为 Python Web 开发量身打造的"ORM 终极解决方案",它将 Pydantic 模型与 SQLAlchemy 深度融合,让开发者在编写 API 时无需在数据库模型和 API 模型之间反复…...
SEO_10个提升网站排名的实用SEO技巧分享(370 )
SEO:10个提升网站排名的实用SEO技巧分享 在当今的互联网时代,一个网站的成功离不开搜索引擎优化(SEO)。SEO不仅仅是一套技术,更是一种思维方式。本文将详细分享十个实用的SEO技巧,帮助你提升网站的排名,吸…...
第二桌面 + 小龙虾:让企业AI智能体安全落地、全员可用
本文发布于2026年4月1日。引言:从“养虾”到“用虾”,AI落地需要新底座过去几个月,OpenClaw(昵称“小龙虾”)在开发者圈子里火得一塌糊涂。这个开源AI智能体网关,能听懂人话,还能替你操作电脑、…...
TEMOS
TEMOS(Text-conditioned Motion Synthesis)是2022年提出的一个文本驱动动作生成模型,核心设计是:文本编码器 动作编码器 动作解码器输入文本描述 → 生成对应的3D动作序列训练时用 KL 散度损失让文本和动作的隐空间分布对齐&…...
忍者像素绘卷效果对比:亮色像素美学 vs 传统暗调像素艺术表现力
忍者像素绘卷效果对比:亮色像素美学 vs 传统暗调像素艺术表现力 1. 作品概述 忍者像素绘卷是一款基于Z-Image-Turbo深度优化的图像生成工作站,它将忍者文化与16-Bit复古游戏美学完美融合。这款工具最显著的特点是采用了全新的"亮色像素"界面…...
效率飙升,跳过proteus安装配置,用快马ai秒建仿真项目
最近在做一个温度监测系统的项目,需要验证电路设计的可行性。按照传统方式,我得先下载安装Proteus软件,配置各种库文件,光是环境准备就得折腾半天。不过这次尝试了用InsCode(快马)平台的AI功能,整个过程变得异常高效。…...
