热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JS数据结构与算法替换字符串的空格

转载自力扣剑指Offer第五题思路整理:大致方法:双指针此想法来自于JS题解点赞量最高的大佬膜拜大佬~首先我们要了解英文的空格符占了一个字符单位中文的空格符占了两个字符单位此题为英



cover from  Leetcode
转载自 力扣 剑指Offer 第五题

思路整理:

大致方法: 双指针
此想法来自于JS题解点赞量最高的大佬 膜拜大佬~

首先我们要了解 英文的空格符 占了一个字符单位
中文的空格符 占了两个字符单位
此题 为英文空格符
题中 将空格替换成 '%20'占了三个字符单位
本题运用双指针
需要比较原字符串长度 和 新占位字符串长度的关系
空格 占 1单位 %20 占3单位 我们记录下原字符串 中空格的数量 得出关系
newLength=oldLength+count*2
我们得出了占位和原字符串长度 下面进行遍历
s指针指向原字符串最后一项 跟 j指针指向占位字符串最后一项 比较
s指针 指向不为空格的时候 j 指针 指向与s指针指向互换
s指针为空格时 开始替换 %20 j指向位置 换成0 位置j-1 换成2 位置j-2 换成%
最后将数组转换为字符串

var replaceSpace = function(s) {
s=s.split('')
var count=0
let oldLength=s.length
for(let i=0;i if(s[i]===' ')
{
count++
}
}
s.length+=count*2
for(let j=s.length-1,c=oldLength-1;c>=0;j--,c--){
if(s[c]!==' ')
{
s[j]=s[c]
}
else{
s[j]='0'
s[j-1]='2'
s[j-2]='%'
j-=2
}
}
return s.join('')
};


推荐阅读
  • Web开发实践:创建连连看小游戏
    本文详细介绍了如何在Web环境中开发一款连连看小游戏,适合初学者和技术爱好者参考。通过本文,您将了解游戏的基本结构、连线算法以及实现方法。 ... [详细]
  • Excel技巧:单元格中显示公式而非结果的解决方法
    本文探讨了在Excel中如何通过简单的方法解决单元格显示公式而非计算结果的问题,包括使用快捷键和调整单元格格式两种方法。 ... [详细]
  • 理解浏览器历史记录(2)hashchange、pushState
    阅读目录1.hashchange2.pushState本文也是一篇基础文章。继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变 ... [详细]
  • 本文探讨了在不同场景下如何高效且安全地存储Token,包括使用定时器刷新、数据库存储等方法,并针对个人开发者与第三方服务平台的不同需求提供了具体建议。 ... [详细]
  • This article explores the process of integrating Promises into Ext Ajax calls for a more functional programming approach, along with detailed steps on testing these asynchronous operations. ... [详细]
  • SPFA算法详解与应用
    当图中包含负权边时,传统的最短路径算法如Dijkstra不再适用,而Bellman-Ford算法虽然能解决问题,但其时间复杂度过高。SPFA算法作为一种改进的Bellman-Ford算法,能够在多数情况下提供更高效的解决方案。本文将详细介绍SPFA算法的原理、实现步骤及其应用场景。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • 探讨了在HTML表单中使用元素代替进行表单提交的方法。 ... [详细]
  • 使用Matlab创建动态GIF动画
    动态GIF图可以有效增强数据表达的直观性和吸引力。本文将详细介绍如何利用Matlab软件生成动态GIF图,涵盖基本代码实现与高级应用技巧。 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • Java高级工程师学习路径及面试准备指南
    本文基于一位朋友的PDF面试经验整理,涵盖了Java高级工程师所需掌握的核心知识点,包括数据结构与算法、计算机网络、数据库、操作系统等多个方面,并提供了详细的参考资料和学习建议。 ... [详细]
  • 本文详细介绍了PHP中几个常用的数组回调函数,包括array_filter、array_map、array_walk和array_reduce。通过具体的语法、参数说明及示例,帮助开发者更好地理解和使用这些函数。 ... [详细]
  • Java中提取字符串的最后一部分
    本文介绍了如何使用Java中的substring()和split()方法来提取字符串的最后一部分,特别是在处理包含特殊字符的路径时的方法与技巧。 ... [详细]
  • 本文旨在探讨Swift中的Closure与Objective-C中的Block之间的区别与联系,通过定义、使用方式以及外部变量捕获等方面的比较,帮助开发者更好地理解这两种机制的特点及应用场景。 ... [详细]
  • 本文探讨了线性表中元素的删除方法,包括顺序表和链表的不同实现策略,以及这些策略在实际应用中的性能分析。 ... [详细]
author-avatar
快乐生鹤
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有