高职网站建设专业书贵安新区网站建设

张小明 2025/12/20 17:01:18
高职网站建设专业书,贵安新区网站建设,邯郸市递加网络有限公司,网站建设华科技给一个字符串#xff0c;他按一定规律进行编码#xff0c;对他进行解码#xff0c;具体就不解释了#xff0c;不过有个还需要知道#xff0c;编码的字符串时有嵌套的情况的 比如 33[aa33[aa]] 这样 算法思想 a3[a]2[bc] 对这个字符串解码 那么会有这俩中情况 cur表示遍历…给一个字符串他按一定规律进行编码对他进行解码具体就不解释了不过有个还需要知道编码的字符串时有嵌套的情况的 比如 33[aa33[aa]] 这样算法思想a3[a]2[bc]对这个字符串解码 那么会有这俩中情况 cur表示遍历到的数组下标cur为字母直接拼接到放回需要放回的字符串上如果为数字那么之后的字符就会设计到解码了而者解码就涉及了三步1 获取到数字 字符串解码的次数 x2 获取到字符串3 将字符串复制 x 次之后将解码好的字符串拼接到最终结果中如果不涉及到嵌套的解码话那么以上这样就已经能够解决了额但是是有这种情况的所以解码方法中也会涉及到相同的解码逻辑这就可以使用递归了所以 解码方法的具体逻辑应该时这样// 获取到解码次数// 获取到字符串 - 判断是否有数字有 递归 解码没有 正常逻辑// 复制字符串// 放回解码好的字符串大的方向就是这样但是还涉及到几个细节问题1. 最重要的 字符串的遍历问题 因为在递归中下标时不共享的那么不知道当前已经递归到哪个下标方法一 可以将 返回值改为 单枪递归完的下标把复制好的额字符串给作为全局变量这样在方法中 把复制的字符串给评到全局变量中但是又因为涉及到递归的原因这个全局变量拼接时会是反者的 具体来说是这样 2[aa1[bb]] - bbaabbaa 因为他是从尾巴添加嘛导致解码字符串顺序乱了而且这样还会涉及到当前 ] 是谁的的问题需要对放回的下标 这样下标会跳跃起来变得不可控和复杂所以这样是不行的 这是我第一次写的 没过 方法二 既然会又字符串的顺序问题那么就可以让他放回字符串将放回的字符串又拼接到当前的需要复制的字符串后就解决了那下标的问题呢 那就让下标改为全局的正好这个下标也是不会回退一个一个的遍历整个字符串很适合且这样还可以少了解决 ] 和 下标跳跃的事能解决2 字符串的拼接既然已经确定使用一个全局的下标遍历和放回解码好的字符串那么其实者就很简单了因为会将字符串放回所以只需要一个作用域是方法的字符串就来拼接需要解码方法放回的字符串就行其实只需要把第一个想出来那么这题就很明朗了 尤其是放回解码好的字符串之前想的是放回下标来解决方法之间的下标问题这样下标会跳着走特别麻烦和不可控代码实现// 全局的遍历下标 int cur 0; public String decodeString(String s) { StringBuilder ans new StringBuilder(); for (; cur s.length(); cur) { if (s.charAt(cur) 0 s.charAt(cur) 9) { ans.append(dfs(s)); } else if (s.charAt(cur) a s.charAt(cur) z) { ans.append(s.charAt(cur)); } } return ans.toString(); } // dfs 表示处理一次3[ab] 的操作 cur 是第一次遇到了数字 返回的是]的下标 // cur开始这个位置可能 会有嵌套的 那么需要第字符串原地的修改 可以使用insert来对index位置插入字符串 // 这个储存最终要复制的字符串 StringBuilder dfs(String s) { // 当前的解码字符串 StringBuilder curCopy new StringBuilder(); //获取到数字 int prev cur; while (s.charAt(cur) 0 s.charAt(cur) 9) cur; String times s.substring(prev, cur); // System.out.println(循环次数 times p prev c cur); //获取到复制字符串 这里cur应该是[ prev cur 1; while (s.charAt(cur) ! ]) { // 为数字说明嵌套了 if (s.charAt(cur) 0 s.charAt(cur) 9) { curCopy.append(dfs(s)); // System.out.println(嵌套str curCopy); } else if (s.charAt(cur) a s.charAt(cur) z) { curCopy.append(s.charAt(cur)); } cur; } // System.out.println(找到复制的字符串 curCopy p prev c cur); // 循环添加 String tmp curCopy.toString(); for (int i 0; i Integer.parseInt(times) - 1; i) { curCopy.append(tmp); } // System.out.println( 当前的解码字符串 curCopy p prev c cur times); return curCopy; }
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

企业建网站的步骤室内设计软件自己设计

还在为Blender内置渲染器的物理精度不足而烦恼吗?Mitsuba-Blender插件为你提供了完美的解决方案。这款强大的集成工具将学术界公认的物理渲染器Mitsuba无缝融入Blender环境,让艺术家和研究人员都能享受到最前沿的渲染技术。🎯 【免费下载链接…

张小明 2025/12/20 19:14:41 网站建设

外贸网站推广如何做新任上海市领导调整公示

第一章:高危漏洞预警概述 在当前复杂的网络环境中,高危漏洞的爆发往往会在短时间内对全球范围内的信息系统造成严重威胁。及时发现并响应这些漏洞,是保障系统安全的核心环节。高危漏洞通常指那些可被远程利用、无需用户交互即可执行任意代码、…

张小明 2025/12/20 18:02:04 网站建设

办个网站需要多少钱如何查看一个网站做的外链

文|魏琳华编|王一粟年底似乎又到了AI厂商们展示实力的日子。上周,快手上演了一场为期五天的全能灵感周技术展示;本周,智谱的连续开源也如期而至。在这五天的时间内,快手带来了三个大模型、一个助力AI落地的…

张小明 2025/12/20 19:17:30 网站建设

如何做英文网站推广免费外链工具

01 生活哪有那么多弯弯绕, 无非是干饭香、躺平爽, 给自个儿整点儿乐子, 给朋友唠句玩笑。 忙到飞起不抓狂,闲下来不瞎慌, 鸡毛蒜皮的日子里, 怎么舒坦怎么浪~ 02 你瞎操心的事儿,八…

张小明 2025/12/20 18:59:52 网站建设

做门户网站需要准备什么wordpress关键词在哪

如果你和我的团队一样,长期维护着一个庞大却脆弱的 UI 自动化测试脚本库,一定对这样的场景再熟悉不过:前端一次看似微小的改动——可能只是一个 CSS 类名变更,或组件结构的轻微调整——就足以让大量测试脚本集体失效。修复它们不仅…

张小明 2025/12/20 17:12:36 网站建设

芜湖公司企业排名网站权重优化方式

虚实融合,数字人开启智能交互新纪元随着人工智能、图形渲染与大数据技术的深度融合,AI数字人已从概念演示快速演进为驱动产业数字化与社会服务智能化变革的关键力量。它不再是简单的动画形象,而是集成了自然语言理解、语音交互、情感计算与高…

张小明 2025/12/20 17:03:09 网站建设