判断一个符串(数组)是不是回文字符串(数组)**
需求:一个字符串(数组)顺着读和反着读都是一样的,举个🌰。字符串:LEVEL即是一个回文字符串(数组同理),LEVELE则不是一个回文字符串(数组)。
思路:根据字符串(数组)的下标将字符串(数组)中的单个字符拿出来和第一个和最后一个比较,第二个和倒数第二个比较以此类推直到前一个下标大于后一个下标,表示全部对比完成。这时候我们就会发现,其实我们只需要在做循环时让数组循环一半即可,因此得出比较次数为字符串(数组)的length属性/2即可,循环次数已经确定,可以使用for循环遍历字符串(数组),是回文则返回true,不是则返回flase。
实现方法:
``
function mirror(arr){
for(var i=0;i<parseInt(arr.length/2);i++){
if(arr[i]==arr[arr.length-1-i]);
else{
return false;
}
}
return true;
}
注意:字符串(数组)的length/2时一点要加parseInt做取整操作,避免循环过程中出错,最后一个字符的下标是字符串(数组)的长度-1,因为字符串(数组)的下标是从0开始的,每循环一次减去i的值跳到前一个下标。