js 驗(yàn)證支付密碼 6位數(shù)字不能相同 不能順序和逆序

思路 ,[0,0,0,0,0,0] [1,2,3,4,5,6] [6,5,4,3,2,1] 都是等差數(shù)列 就是判斷是否為等差數(shù)列

1. 原數(shù)組 去重 正序排列

2.遞歸 獲取等差值

3.等差值 去重?

4.判斷等差值(去重后數(shù)組長度分3種情況 0:相同數(shù)子, 1:順序或逆序 ,其他:正確)


let arr = [9,1,7,6,5,4]

class verifications {

constructor() {

this.val = []

}

// 正序排列 去重

? ? _init(val) {

this.val = this.DuplicateRemoval(val.sort(function (a,b) {

return a - b;

}))

}

handle(val) {

this._init(val)

let newVal = this.DuplicateRemoval(this._filters(this.val))

if (newVal.length !== 0 && newVal.length !== 1) {

return true

? ? ? ? }else {

return false

? ? ? ? }

}

// 遞歸處理等差數(shù)列

? ? _filters(val,newVal = [],index = 0) {

if (index <= val.length - 2) {

newVal.push(val[index + 1]- val[index])

index++

? ? ? ? ? ? this._filters(val,newVal,index)

}

return newVal

? ? }

// 去重

DuplicateRemoval(val) {

return Array.from(new Set(val))

}

}

let p = new verifications()

console.log(p.handle(arr))

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容