溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Go?Java算法之Excel表列名稱問題怎么解決

發(fā)布時間:2022-08-12 10:49:34 來源:億速云 閱讀:205 作者:iii 欄目:開發(fā)技術

本篇內(nèi)容主要講解“Go Java算法之Excel表列名稱問題怎么解決”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Go Java算法之Excel表列名稱問題怎么解決”吧!

Excel表列名稱

給你一個整數(shù) 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"  

提示:

1 <= columnNumber <= 231 - 1

方法一:數(shù)學(Java)

根據(jù)題意可知 'A' = chr(1+ord('A')-1) =》2 = chr(2+ord('A') -1) ,因此類似10進制一樣從個位開始匹配

使用循環(huán),首先求余,若余數(shù)為0,則說明是26的倍數(shù),則需要columnNumber-= 26,然后將余數(shù)=26,然后求倒數(shù)第二位,。。。直到最高位即最左邊第一位求余為0為止,拼接的字符串翻轉即為答案。

class Solution {
    public String convertToTitle(int columnNumber) {
        StringBuffer sb = new StringBuffer();
        while (columnNumber != 0) {
            columnNumber--;
            sb.append((char)(columnNumber % 26 + 'A'));
            columnNumber /= 26;
        }
        return sb.reverse().toString();
    }
}

cloumnNumber:轉換位26進制的位數(shù)

時間復雜度:O(log26(columnNumber))

空間復雜度:O(1)

方法一:數(shù)學(Go)

具體的方法思路已經(jīng)在上文中表述,詳情請看上文內(nèi)容。

將十進制轉二十六進制,先取余再除直到num == 0,由于1 對應 A,所以起始num - 1

  • 先創(chuàng)建一個26進制的數(shù)字和其對應的字母map

  • 對總數(shù)字取26的余數(shù),通過map獲取其相應的字母,注意當余數(shù)為0的時候余數(shù)是為26

  • 將數(shù)字減去余數(shù)后除以26,這步主要剔除個位數(shù),將十位數(shù)移到個位數(shù),再進行上述的同樣處理

func convertToTitle(columnNumber int) string {
    ans := []byte{}
    for columnNumber > 0 {
        columnNumber--
        ans = append(ans, 'A'+byte(columnNumber%26))
        columnNumber /= 26
    }
    for i, n := 0, len(ans); i < n/2; i++ {
        ans[i], ans[n-1-i] = ans[n-1-i], ans[i]
    }
    return string(ans)
}

cloumnNumber:轉換位26進制的位數(shù)

時間復雜度:O(log26(columnNumber))

空間復雜度:O(1)

到此,相信大家對“Go Java算法之Excel表列名稱問題怎么解決”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關內(nèi)容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI