17.电话号码的字母组合

一、题目原型:

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

电话按键

二、题目意思剖析:

其实呢就是一个排列组合,将字母按照有序的顺序组合起来。

/*
    2-abc
    3-def
    4-ghi
    5-jkl
    6-mno
    7-pqrs
    8-tuv
    9-wxyz
 
   输入:"23"
   输出:["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].
   如果输入的是 245
   输出:["agj", "agk", "agl", "ahj", "ahk", "ahl", "aij", "aik", "ail"......
 */

三、解题思路:

我呢是用swift语法来做,但是逻辑思路都是相通的。
第一想到的应该是递归。通过递归,再加上一些判断条件,将对应的字符串加入进数组。

// 1.最外围的主方法
func letterCombinations(_ digits: String) -> [String] {
    if digits.isEmpty {
        return []
    }
    //  由于swift语法特性,需要将digits字符串包装为一个数组
    var strings: [String] = []
    for digit in digits {
        let str: String = String.init(digit)
        strings .append(str)
    }
    haha(strings,0)
    return result
}
// 2.核心代码实现
func haha(_ strings: [String], _ index: Int) {
    if str.count == strings.count {
        result .append(str)
        return
    }
    // 防止数组越界
    if index >= strings.count {
        return
    }
    // 1.首先我们需要一个电话号码base数组。
    let bases: [[String]] = [[""],[""],["a","b","c"],["d","e","f"],["g","h","i"],["j","k","l"],["m","n","o"],["p","q","r","s"],["t","u","v"],["w","x","y","z"]]
    // 2.通过index索引将strings对应的字符串元素转换为Int类型的索引
    // baseIndex : 电话号码(数字)索引,比如strings=["2","4","5"],baseIndex就是2,4,5
    let baseIndex: Int = (Int)(strings[index])!
    for i in 0..<bases[baseIndex].count {
        // 拿到子数组里对应的字母
        let baseStr: String = bases[baseIndex][i]
        // 1.如果当前正在添加第一个字母,就将str清空
        if index == 0 {
            str .removeAll()
        }
        /* 2.如果当前正在添加最后一个字母,并且不是第一个字母串,就删除str的最后一个字符
             比如index = 2,说明在添加第三个字母,如果i不等于0,就需要把最后一个字母删除。
             "agj", "agk", "agl"
             过程 : agj - ag - agk - ag - agl
         */
        else if index == strings.count - 1 && i != 0{
            str .removeLast()
        }
        else {
            // 3.如果str不为空,需要删除字母串的后面几位,通过index来设定
            // 用str的长度 - index得到后面需要删除的长度
            // "jmpt", "jmpu", "jmpv", "jmqt", "jmqu", "jmqv", "jmrt", "jmru", "jmrv", "jmst", "jmsu", "jmsv
            
            // 比如当前字符串为 jmrv,index为2,就需要删除后面 4 - 2 = 2,删除后面2位。
            // baseStr为s,然后接下来的baseStr为t。
            // 过程 : jmrv - jm - jms - jmst
            if !str.isEmpty {
                str .removeLast(str.count - index)
            }
        }
        str .append(baseStr)
        haha(strings, index + 1)
    }
}

四、小结

有时候这类题都是去找规律,我们需要把一些例子所得到的数据展示出来,然后去寻找规律,让计算的过程直观的表达出来。
注:可以在haha方法里加入一个indexs数组,result也不要限定条件来添加,然后直接在letterCombinations方法里打印出indexs和result的值。这样可以非常直观的查看添加过程。

func haha(_ strings: [String], _ index: Int) {
    indexs .append(index)
    result .append(str)
    、、、后面的代码不变
}
总提交数.png

提交结果.png

有任何疑问都可以留言,非常乐意一起探讨。😄

个人博客地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容