Javascript|数据类型|String类型常见算法

1. 字符串逆序输出

方法一:先转化成数组,再逆序,再拼接回String

// 数组 reverse()
function reverseString1(str){
  return str.split('').reverse().join('')
}

方法二:for循环+chartAt(),倒序,逐个拼接

function reverseString2(str){
  var n= str.length-1
  var result = ''
  for(var i=n;i>=0;i--;){
   return result+=str.charAt(i)
  }
}

方法三:类同方法二,递归+charAt()

function reverseString3(str,pos,strOut){
  if(pos<0)
    return strOut
  strOut+=strIn.charAt(pos--)
  return reverseString3(strIn,pos,strOut)
}

方法四:调用call()函数后,让字符串具有数组的特性,在调用未传入参数的slice()函数后,调用reverse(),再调用join()函数,得到逆序字符串

function reverseString4(){
  var arr= Array.prototypr.slice.call(str)
  return arr.reverse().join('')
}

方法五:借助栈的先进后出原则

//栈
function stack(){
  this.data=[];
  this.top=0;
}
stack.prototype={
  push:function push(elemnet){
    this.data[this.top++]=elemnt
  }
  pop:function pop(){
  	return this.data[--this.top]
	}
  length:function(){
    return this.top
  }
}

function reverseString5(){
  var s=new stack()
  var arr=str.split('')
  var len=arr.length;
  var result=''

  for(var i=0;i<lenth;i++){
    s.push(arr[i])
  }

  for(var j=0;j<lenth;j++){
    reslut+=s.pop(j)
  }
}

2.统计字符串出现次数最多的字符及出现的次数

方法一:遍历字符串,通过key-value的对象来存储数据,遍历对象,判断条件,统计出现次数

function getMaxCount(str){
  var json={}
  for(var i=0;i<str.length;i++){
    if(!json[str.charAt(i)]){
      json[str.charAt(i)]=1
    }else{
      json[str.charAt(i)]++
    }
  }
  var maxCountChar=''
  var maxcount=0

  for(var key in json){
    if(json[key]>maxCount){
      maxCount=json[key]
      maxCountChar=kley
    }
  }
  retrun '出现最多的值是'+maxCountChar+'出现次数为'+maxCount
}
var str='gfdshghsdghsodhgiodskgdlsnvjnkpjgpfdjsgjdso'
getMaxCount(str)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值