使用JavaScript字符串解决回文数的方案详解

 更新时间:2024年05月07日 09:15:14   作者:长安故里_  
这篇文章主要介绍了使用JavaScript字符串解决回文数的方案,JavaScript中的字符串是一种数据类型,用于表示文本数据,字符串可以包含任意字符序列,包括字母、数字、符号和空格,灵活掌握字符串的解决问题思想,巧用字符串解决回文数,需要的朋友可以参考下

前言:

JavaScript中的字符串是一种数据类型,用于表示文本数据。字符串可以包含任意字符序列,包括字母、数字、符号和空格。灵活掌握字符串的解决问题思想,巧用字符串解决回文数。

正文

1.如何将字符串中的一个字符移除掉

思路一:想想字符串中是否自带一个方法将某一个字符移除?借问搜索引擎,没有此方法。

思路二:JS中是否有别的数据结构能够移除其中的一个字符,再将字符串转化为为那个数据结构。是的,数组有这个功能,只要将字符串转化为数组就行。

实现功能:

let str = 'hello world'

console.log(str.split(''));

split将字符串中的每一个字符都作为一个元素放到数组中去。紧接着如何移除一个字符 e ?

let str = 'hello world'

console.log(str.split('').splice(1,1));

会发现,这并不能移除 e 而是返回下标1的字符 e 。这里可以自定义一个数组进行移除。

let str = 'hello world'

let strArr = str.split('')
strArr.splice(1,1)
console.log(strArr);

通过定义一个 strArr 的数组,在进行下标的移除,此时 strArr 不会在受到影响。

但需要面临的问题是,这是数组下的splice方法,如何使数组转化为字符串?仍是两种思路

思路一:数组自带一个方法住转化为字符串(join)

以横杠的方式进行字符串的拼接。

思路二:自己手搓一个方法,将数组中的元素一个一个转化为字符储存在字符串中。

let str = 'hello world'

function spliceStr (str,index) {
    let newStr = ''
    for (let i = 0;i < str.length;i++) {
        if( i != index)
        newStr += str[i]
    }
    return newStr
} 

console.log(spliceStr(str,1));

给出 str 的一个下标,遍历每一个字符串,将每一个str 的下标加到 newStr 中去,但是为了不让,每一个都加到 newStr 中,给出一个判断语句,if( i != index),满足所有的条件才加到里面去,最后返回结果。

结果符合预期。

2.切割一个字符串(slice)

字符串中存在一个方法自己进行切割其中的字符,slice 。

let str = 'hello world'

console.log(str.slice(1,3));
console.log(str);

这里会发现,字符串本身不会受到影响,会将切割的字符移除。并且,这是一个左闭右开的区间【即包含下标一的字符不包含下标三的。】

这里就是大概字符串的介绍。

3.如何使用字符串解决回文数【从右到左和从左到右一样】

let str = 'ababa'

function isPalindrome(str) {
    let arr = str.split('').reverse()
    let newStr = arr.join('')
   if(str == newStr){
    console.log();
    return true
   }
}
isPalindrome(str)

将字符串转化为数组 let arr = str.split('').reverse(),然而数组是复杂数据类型,无法进行直接相等比较,在将数组转化为字符串这种简单数据类型 let newStr = arr.join(''),在将if相等比较,最后返回true。

let str = 'ababa'

function isPalindrome(str) {
    let i = 0
    let j = length - 1

    while(i < j){
        if(str[i] === str[j]){
            i++
            j--
        }else {
            return false
        }
    }
}

isPalindrome(str)

这里左右手各拿一个数,依次遍历比较两个值是否相等?若不相等,则返回false,否则就是true,就判断出这是回文数。

结果没有返回false,所以没问题。

总结

理解字符串做算法题的思路:1:从自身方法中去找 2:自己手搓一个方法来解决问题。

这两个思路很重要,再就是从左右两边用指针来进行回文数的比较。

以上就是使用JavaScript字符串解决回文数的方案详解的详细内容,更多关于JavaScript字符串解决回文数的资料请关注脚本之家其它相关文章!

相关文章

  • 封装获取dom元素的简单实例

    封装获取dom元素的简单实例

    下面小编就为大家带来一篇封装获取dom元素的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-07-07
  • 如何正确理解javascript的模块化

    如何正确理解javascript的模块化

    模块化在项目中十分的重要,一个复杂的项目肯定有很多相似的功能模块,如果每次都需要重新编写模块肯定既费时又耗力。但是引用别人编写模块的前提是要有统一的“打开姿势”,如果每个人有各自的写法,那么肯定会乱套,下面介绍几种JS的模块化的规范。
    2017-03-03
  • 用JS实现网页元素阴影效果的研究总结

    用JS实现网页元素阴影效果的研究总结

    用JS实现网页元素阴影效果的研究总结...
    2007-08-08
  • 解决layui页面按钮点击无反应,也不报错的问题

    解决layui页面按钮点击无反应,也不报错的问题

    今天小编就为大家分享一篇解决layui页面按钮点击无反应,也不报错的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • js取两个数组的交集|差集|并集|补集|去重示例代码

    js取两个数组的交集|差集|并集|补集|去重示例代码

    求两个集合的补集、交集、差集、并集等等在实际应用中经常会使用到,下面与大家分享下具体的实现代码,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08
  • div模拟滚动条效果示例代码

    div模拟滚动条效果示例代码

    滚动条想必大家都见过吧,在本文将使用div来模拟滚动条的效果,具体实现如下,感兴趣的朋友可以参考下
    2013-10-10
  • 如何动态加载外部Javascript文件

    如何动态加载外部Javascript文件

    这篇文章主要介绍了如何动态加载外部Javascript文件,本文举例讲解使用js加载器动态加载外部Javascript文件,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • JavaScript进阶练习及简单实例分析

    JavaScript进阶练习及简单实例分析

    下面小编就为大家带来一篇JavaScript进阶练习及简单实例分析。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • js原生map实现的方法总结

    js原生map实现的方法总结

    在本篇文章里小编给大家整理了关于js原生map实现的方法以及实例分析内容,需要的朋友们可以参考下。
    2020-01-01
  • Javascript 匿名函数及其代码模式原理

    Javascript 匿名函数及其代码模式原理

    很多同学知道怎么用这种匿名函数,却或许并不明白为什么这样写就能够调用匿名函数。也许知道后面的圆括号是执行前面的函数,而并不清楚前面的圆括号具有何种含义!本文将带你了解匿名函数的代码模式原理。
    2010-03-03

最新评论