Java泛型類程式設計測試
阿新 • • 發佈:2021-12-22
<script>
//利用雙層迴圈實現陣列去重
function unique() {
var arr = [1,2,3,4,4,4,5]; //陣列
var hash = []; //定義新陣列
for (var i = 0; i < arr.length; i++) { //外層迴圈
for (var j = i + 1; j < arr.length; j++) { //內層迴圈
if (arr[i] === arr[j]) { //當出現重複的元素
++i; //i++ 跳出內層迴圈 新一輪的外層迴圈
}
}
hash.push(arr[i]); //將遍歷去重數後的陣列新增到新陣列中
}
return hash; //函式返回新陣列
}
console.log(unique());
//利用下標實現陣列去重
function unique() {
var arr = [2, 8, 5, 0, 5, 2, 6, 7, 2]; //定義陣列
var hash = []; //定義新陣列
for (var i = 0; i < arr.length; i++) { //遍歷迴圈陣列
if (hash.indexOf(arr[i]) == -1) { //當新陣列中沒有這個元素
hash.push(arr[i]); //這個元素新增進新陣列
}
}
return hash; //返回新陣列
}
console.log(unique());
</script>
查詢陣列中重複最大的元素和次數
//方法一:陣列遍歷 物件遍歷
function findMost() {
var arr = [3, 5, 6, 5, 9, 8, 10, 5, 7, 7, 10, 7, 7, 7, 7, 10, 10, 10, 10, 10]; //定義陣列
if (!arr.length) return //當陣列為空時,返回
if (arr.length === 1) return 1 //當陣列中只有一個元素時,返回1
let res = {} //定義物件
let maxName, maxNum = 0; //定義maxName,maxNum變數
// 利用forEach()方法遍歷陣列
arr.forEach((item) => {
res[item] ? res[item] += 1 : res[item] = 1 ;
//將遍歷的陣列轉換成物件中key-value的鍵值對 並存入物件res中
// 3:1
// 5:1 2 3
// 6:1
// 9:1
// 8:1
// 10:1 2 3 4 5 6 7
// 7:1 2 3 4 5 6
//forEach()方法將屬性排序後,傳入res物件中,沒有返回值
});
console.log(res);
// 利用for...in()方法 遍歷 res物件的屬性
for (let r in res) {
if (res[r] > maxNum) { //比較res中屬性的對應value值,當大於變數maxNum時
maxNum = res[r]; //將value值賦值給maxNum
maxName = r; //將對應的屬性賦值給maxName
}
}
return '出現次數最多的元素為:' + maxName + ', 出現次數為:' + maxNum; //返回
}
console.log(findMost());
//方法二:遍歷陣列 將物件遍歷省略
function findMost() {
var arr = [3, 5, 6, 5, 9, 8, 10, 5, 7, 7, 10, 7, 7, 7, 7, 10, 10, 10, 10, 10]; //定義陣列
if (!arr.length) return;
if (arr.length === 1) return 1;
let res = {};
let maxName, maxNum = 0;
// 遍歷陣列
arr.forEach((item) => {
res[item] ? res[item] += 1 : res[item] = 1;
if (res[item] > maxNum) {
maxName = item;
maxNum = res[item];
}
});
return '出現次數最多的元素為:' + maxName + ', 出現次數為:' + maxNum;