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.得到數組中連續相同的最大個數,應用場景,選擇題判斷的時候,有規定連續幾個以上的時候視為無效的答案,這個時候我門把問題的答案放到了一個數組里面,最后判斷是否符合要求。我的代碼如下,總是感覺寫法不好。希望有好的寫法可以告知一下,謝謝v17346598520
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;
}
}