当前位置: 首页 > news >正文

百度wap网站建设网络广告营销的典型案例

百度wap网站建设,网络广告营销的典型案例,管理软件属于什么软件,网站建站工具文章目录 前言LeetCode、17. 电话号码的字母组合【中等,dfs回溯】题目与类型思路递归回溯优化:StringBuilder来回溯补充代码:2024.1.31(简化) 资料获取 前言 博主介绍:✌目前全网粉丝2W,csdn博…

文章目录

  • 前言
  • LeetCode、17. 电话号码的字母组合【中等,dfs回溯】
    • 题目与类型
    • 思路
      • 递归+回溯
      • 优化:StringBuilder来回溯
      • 补充代码:2024.1.31(简化)
  • 资料获取

前言

博主介绍:✌目前全网粉丝2W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、算法、分布式微服务、中间件、前端、运维、ROS等。

博主所有博客文件目录索引:博客目录索引(持续更新)

视频平台:b站-Coder长路


LeetCode、17. 电话号码的字母组合【中等,dfs回溯】

题目与类型

学习:leetcode题解

题目链接:17. 电话号码的字母组合

题目内容:给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。

题目类型:搜索与图论/回溯、基础算法/枚举

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。


思路

本题是要得到所有电话号码的字母组合,这实际上就是全排列(dfs),其中就包含回溯的一个操作处理,我们可以使用一个临时保留或者尝试使用回溯思路来实现。


递归+回溯

思路:由于循环的个数不确定,则需要使用递归来进行求解。

代码:时间复杂度O(3m×4n)、空间复杂度O(m+n)

class Solution {/*** 根据指定字符生成字符串* @param ch 数字字符* @return*/public String generateNumtoString(char ch){String[] arr = new String[] {"abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};if (ch - '2' <= arr.length){return arr[ch - '2'];}return null;}private List<String> letters = new ArrayList<>();/*** 全排列 :abc、def、ghip* @param arr 数组集合* @param curIndex 当前要遍历的指定数组* @param curArrIndex 当前排列的个数* @param genStr 当前生成的字符串*/public void quanpailie(String[] arr, int curIndex, int curArrIndex, String genStr){//生成每组的排列个数if(curArrIndex == arr.length){letters.add(genStr);return;}String curArr = arr[curIndex];//取得当前要遍历的数组String temp = genStr; //临时保存原先状态for (int i = 0; i < curArr.length(); i++) { //枚举所有情况genStr += curArr.charAt(i);quanpailie(arr,curIndex + 1, curArrIndex + 1, genStr);genStr = temp; //回溯}}public List<String> letterCombinations(String digits) {if (Objects.equals("",digits)){return new ArrayList<>();}String[] arrs = new String[digits.length()];for (int i = 0; i < digits.length(); i++) {arrs[i] = generateNumtoString(digits.charAt(i));}//使用全排列进行求解quanpailie(arrs,0, 0, "");return letters;}}

image-20211208151438197

小优化:对于回溯操作的字符串替换使用StringBuilder,时间、空间效率大幅度提升!

public void quanpailie(String[] arr, int curIndex, int curArrIndex, StringBuilder str){...for (int i = 0; i < curArr.length(); i++) { str.append(curArr.charAt(i));...str.deleteCharAt(curArrIndex);//回溯优化}
}

优化:StringBuilder来回溯

思路:核心优化点就是在字符串回溯、拼接上

/*** 根据指定字符生成字符串* @param ch 数字字符* @return*/
public String generateNumToStr(char ch){String[] arr = new String[] {"abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};if (ch - '2' <= arr.length){return arr[ch - '2'];}return null;
}private List<String> letters = new ArrayList<>();/*** 全排列 :abc、def、ghip* @param phones 电话数字映射的字符串数组* @param index 当前排列的数字位置* @param genStr 当前生成的字符串*/
public void quanpailie(String[] phones, int index, StringBuilder genStr){//生成每组的排列个数if(index == phones.length){letters.add(genStr.toString());return;}String curArr = phones[index];//取得当前要遍历的数组for (int i = 0; i < curArr.length(); i++) { //枚举所有情况genStr.append(curArr.charAt(i));quanpailie(phones,index + 1, genStr);genStr.deleteCharAt(index);}
}public List<String> letterCombinations(String digits) {if (Objects.equals("",digits)){return new ArrayList<>();}String[] arrs = new String[digits.length()];for (int i = 0; i < digits.length(); i++) {arrs[i] = generateNumToStr(digits.charAt(i));}//使用全排列进行求解quanpailie(arrs,0, new StringBuilder(""));return letters;
}

image-20211208153059789

补充代码:2024.1.31(简化)

class Solution {List<String> res = new ArrayList<>();//"23"public List<String> letterCombinations(String digits) {if ("".equals(digits)) return res;//2-9String[] phones = {"abc","def","ghi","jkl", "mno","pqrs","tuv","wxyz"};List<String> phoneList = new ArrayList<>();for (int i = 0; i < digits.length(); i++) {char ch = digits.charAt(i);int num = ch - '0';if (num < 2) continue;phoneList.add(phones[num - 2]);}dfs (0, digits.length(), new StringBuilder(),  phoneList);return res;}public void dfs (int curLevel, int allLevel, StringBuilder str, List<String> phoneList) {//若是层数已经超越了原本的电话拨号数,那么直接添加到集合中if (curLevel >= allLevel) {res.add(str.toString());return;}//当前层编号String phones = phoneList.get(curLevel);for (int i = 0; i < phones.length(); i++) {str.append(phones.charAt(i));dfs (curLevel + 1, allLevel, str, phoneList);str.deleteCharAt(str.length() - 1);//回溯}}
}

image-20240131145824770


资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

  • 长路-文章目录汇总(算法、后端Java、前端、运维技术导航):博主所有博客导航索引汇总
  • 开源项目Studio-Vue—校园工作室管理系统(含前后台,SpringBoot+Vue):博主个人独立项目,包含详细部署上线视频,已开源
  • 学习与生活-专栏:可以了解博主的学习历程
  • 算法专栏:算法收录

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅


整理者:长路 时间:2024.1.31

http://www.yayakq.cn/news/153540/

相关文章:

  • 鞍山做网站优化公司举例网络营销的例子
  • 扬中网站建设案例设计上海2021门票
  • 个人网站用备案吗该网站使用的安全设置
  • 烟台网站开发技术网站代理浏览器一
  • aspx网站开发手机网站生成app客户端
  • 网站开发的账务处理WordPress方糖
  • 郑州网站建设讯息公司设计网站推荐
  • 建瓯网站建设wzjseo类似于微博网站怎么做的
  • 用别人服务器做网站网站建设 案例
  • 注册一个公司需要什么资料云速seo百度点击
  • 网站建设 ipc备案佛山专业网站设计公司
  • 新网站建设流程罗湖网站-建设深圳信科
  • 沈阳地区精神文明建设网站网络推广基础
  • iis默认网站删除google seo是什么
  • 层次结构分明的网站配色方案优秀的软文
  • 汕头建站模板上海建筑工程公司排行榜
  • 建设银行怎么在网站设置限额喀什seo排名
  • 南京做网站优化的企业排名next wordpress
  • 无锡专业网站推广国家企业信用信息公示网官网
  • 公司重名 做网站apache 搭建多个网站
  • 网站404页面制作免费html5播放器
  • 网站建设app开发合同蓝盟it外包
  • 忆唐网不做网站做品牌菏砖网站建设
  • 想学做网站整站优化seo公司哪家好
  • html5网站开发视频广州网络推广奋
  • 珠海舒讯网站建设musik wordpress视频
  • 网站建设的运营计划书动易网站安装子目录中
  • 合肥专业网站优化哪家好seo是搜索引擎优化吗
  • 上海网站制作培训班世界购物平台排行榜
  • 微网站用什么做的属于c2c的网站是