1,力扣题905:按奇偶排序数组
给你一个整数数组 nums
,将 nums
中的的所有偶数元素移动到数组的前面,后跟所有奇数元素。返回满足此条件的 任一数组 作为答案。
分析:(1)、for循环遍历数组,找到偶数元素。
(2)、找到偶数元素后,再遍历之前的元素找奇数元素,利用数组解构交换元素实现元素 交换。
(一开始想到只遍历一次找到偶数元素之后用splice()和unshift()两个数组方法来实现,但经过测验后发现不可以这样)
注意:在第一次遍历时,因为第一个元素无论奇数偶数都没必要移动,所以可以从第二 个元素开始。
代码:
let nums=[1,2,3,4,5,6,7,8,9];
for(let i=1;i<nums.length;i++){
if(!(nums[i]%2)){
for(let j=0;j<i;j++){
if(nums[j]%2){
[nums[i],nums[j]]=[nums[j],nums[i]];
}
}
}
}
console.log(nums)
输出结果:
2、正则表达式中 * ?
let a="webdhbananan"
let reg=/(an)*/
匹配是从左到右。(an)*前如果没有字符的话,表示空字符串。根据空字符串是所有字符串的子串,所以会匹配成功,索引值为0。
当(an)*前有字符,例如b(an)*,因为*是出现0次或多次,这时会匹配字符串a中的第一个b
并且当a="banananwebdh"时,因为a中b后面有an,所以结果为"bananan"(?同理)
let a="webdhbananan";
let reg=/(an)*/;
let result=a.match(reg);
console.log(result)
结果:
let a="webdhbananan";
let reg=/b(an)*/;
let result=a.match(reg);
console.log(result)
结果:
let a="banananwebdh";
let reg=/b(an)*/;
let result=a.match(reg);
console.log(result)
结果: