1.獲取數組中相同的元素,應用場景,矩陣單選題全部的答案都不能相同,咱們須要對答案數組進行判斷是否有相同的值。數組
// 須要兩個參數,一個是判斷元素,一個是判斷的數組,返回的是這個數組中相同元素數組的個數 function arrSameNums(ele,arr) { var nums=0; for(var i = 0; i < arr.length; i++) { if(arr[i]==ele){ nums++; } } return nums; }
// 判斷數組中是否有相同元素,傳入數組,有的話返回true,沒有返回false function ishaveSameEle(arr) { for(var i = 0; i < arr.length; i++) { var num = 0; var ele = arr[i]; for(var j = 0; j < arr.length; j++) { if(arr[j] == ele) { num++; if(num > 1) { return true; break; } } } } return false; }
2.獲得數組中連續相同的最大個數,應用場景,選擇題判斷的時候,有規定連續幾個以上的時候視爲無效的答案,這個時候我門把問題的答案放到了一個數組裏面,最後判斷是否符合要求。個人代碼以下,老是感受寫法很差。但願有好的寫法能夠告知一下,謝謝v17346598520code
function getArrContinuSameNum(ele, arr) { var sameNum = 0; // 保存連續相同的個數 var sameNumArr = []; // 保存全部個數 var arrPre = arr[0]; // 保存上一個數值,用來判斷是否連續 for(var i = 0; i < arr.length; i++) { if(arr[i] == ele && arr[i] == arrPre) { // 等於上一個,說明連續了 sameNum++; arrPre = arr[i]; } else { sameNum = 0; arrPre = arr[i]; continue; // 這裏的continue是跳出當前循環繼續下一次循環,因此上面的從新賦值操做不能拿到外面來賦值 } sameNumArr.push(sameNum); } if(sameNumArr.length > 0) { sameNumArr.sort(function(m, n) { return n - m; }); return sameNumArr[0] + 1; } else { return 0; } }