您好,登錄后才能下訂單哦!
本篇內容主要講解“Go Java算法之Excel表列名稱問題怎么解決”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Go Java算法之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"
提示:
1 <= columnNumber <= 231 - 1
根據題意可知 'A' = chr(1+ord('A')-1) =》2 = chr(2+ord('A') -1) ,因此類似10進制一樣從個位開始匹配
使用循環,首先求余,若余數為0,則說明是26的倍數,則需要columnNumber-= 26,然后將余數=26,然后求倒數第二位,。。。直到最高位即最左邊第一位求余為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進制的位數
時間復雜度:O(log26(columnNumber))
空間復雜度:O(1)
具體的方法思路已經在上文中表述,詳情請看上文內容。
將十進制轉二十六進制,先取余再除直到num == 0,由于1 對應 A,所以起始num - 1
先創建一個26進制的數字和其對應的字母map
對總數字取26的余數,通過map獲取其相應的字母,注意當余數為0的時候余數是為26
將數字減去余數后除以26,這步主要剔除個位數,將十位數移到個位數,再進行上述的同樣處理
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進制的位數
時間復雜度:O(log26(columnNumber))
空間復雜度:O(1)
到此,相信大家對“Go Java算法之Excel表列名稱問題怎么解決”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。