Вычисление заголовка столбца в Excel

Leetcode задача #168. Excel Sheet column title.
Задача помечена как простая, тем не менее, не сразу понял как её решать.

Дано число, это номер столбца для Excel таблицы, требуется сгенерировать его буквенное имя. Иными словами сопоставить 1 -> A, … 26 -> Z, 27 -> AA …

Вроде бы тривиальная задача о переводе из одной позиционной системы счисления (СС) в другую. Мы хотим перевести из СС с основанием 10 (0…9) в СС с основанием 26 (A…Z).

Нюанс задачи заключается в том, что индексация столбцов в Excel виртуально отбрасывает нас во времена, когда в математике не изобрели числа 0, т.е. примерно на 1,5 тыс. лет назад.

«А» не является в данном случае подобием нуля, т.к. обозначает столбец под номером 1. Потому запись вроде «AA» — трактуется не как ноль-ноль, а как 1 — 1.

Если взять столбец 27, и поделить его на разрядность, то мы получим 1, и еще 1 в остатке, или коротко можно записать вот так:

Что легко читается как A — A. Но если мы берем столбец 26 и проделываем с ним тоже самое:

То здесь вы уже не сможете сопоставить что либо внятное, т.к. нуля у вас нет в данной системе счисления. А должен получится результат «Z».

Что же делать?

Можно попробовать сместить нумерацию на единицу влево. И сказать, что А — это не единица, а ноль, B — это 1, и так далее Z — 25.

Вроде бы выправили ситуацию для этого случая, получилось «Z», который при смещении стал равен 25. Но вернемся снова к столбцу № 27:

Учитывая смещение, это нам даст «BA», вместо «AA». Опять не хорошо.

Этот пример лишь показывает, что «0» это не самая простая концепция в математике. Но подход со смещением, в принципе, верный, только требуется смещать каждый разряд, а не всё число. Произведя смещение однократно, мы делаем правильный шаг только для младшего из разрядов.

Давайте посмотрим на код (TS):

Мало букафф? Читайте есчо !

Результат k-ой перестановки

Июль 5, 2023 г.

Очередная задача с литкода (№60. Permutation Sequence). В общем случае формулируется так: дан набор элементов, требуется вернуть этот набор после k перестановок. ...

Читать

Задача о наибольшей сумме монет

Апрель 15, 2023 г.

Решаем задачу № 2218 с leetcode - Maximum Value of K Coins From Piles. В названии фигурирует слова монеты и стопки. Если представить себе, что монеты могут быть произвольного номинала, то да - суть именно такая. У нас есть стопки монет, и дано число ...

Читать

Задача следующей комбинации (next permutation)

Март 13, 2023 г.

Мне понадобилось какое то время, чтобы понять верный подход к решению, делюсь подробным разбором этой задачи. Ставится она так: есть набор (массив) элементов, чаще всего чисел, требуется найти следующей по порядку возрастания набор этих элементов. ...

Читать

Классическая задача о размене монет

Январь 24, 2023 г.

Дана сумма amount и номиналы монет. Требуется разменять сумму минимальным набором монет. Если рассматривать набор монет, который используется в реальной жизни, т.е. [1коп, 5коп, 10коп, 50коп, 1р, 2р, 5р, 10р], то во-первых, решение всегда существует, ...

Читать
 

Комментарии к «Вычисление заголовка столбца в Excel»

Понравилась статья? Есть вопросы? - пишите в комментариях.



Комментарий: