Skip to content
Open
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 18 additions & 0 deletions quiz/part1/tugas1.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
// Soal 1
//cek apakah angka yang dikirim adalah angka prima atau bukan?
//cek google bagi yang ga tau apa itu angka prima
function angkaPrima(angka) {
for (let i = 2; i < angka; i++) {
if (angka % i === 0) {
return false;
}
}
return true;
}

// TEST CASES
console.log(angkaPrima(3)); // true
console.log(angkaPrima(7)); // true
console.log(angkaPrima(6)); // false
console.log(angkaPrima(23)); // true
console.log(angkaPrima(33)); // false
22 changes: 22 additions & 0 deletions quiz/part1/tugas2.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
// Soal 2
//cari faktor persekutuan terbesar
function fpb(angka1, angka2) {
let terkecil = Math.min(angka1, angka2);
let fpb = 1;

for (let i = terkecil; i >= 1; i--) {
if (angka1 % i === 0 && angka2 % i === 0) {
fpb = i;
break;
}
}

return fpb;
}

// TEST CASES
console.log(fpb(12, 16)); // 4
console.log(fpb(50, 40)); // 10
console.log(fpb(22, 99)); // 11
console.log(fpb(24, 36)); // 12
console.log(fpb(17, 23)); // 1
23 changes: 23 additions & 0 deletions quiz/part1/tugas3.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
function cariMedian(arr) {
arr.sort(function(a, b) {
return a - b;
});

let panjang = arr.length;
let tengah = Math.floor(panjang / 2);


if (panjang % 2 !== 0) {
return arr[tengah];
}
else {
return (arr[tengah - 1] + arr[tengah]) / 2;
}
}

// TEST CASES
console.log(cariMedian([1, 2, 3, 4, 5])); // 3
console.log(cariMedian([1, 3, 4, 10, 12, 13])); // 7
console.log(cariMedian([3, 4, 7, 6, 10])); // 6
console.log(cariMedian([1, 3, 3])); // 3
console.log(cariMedian([7, 7, 8, 8])); // 7.5
26 changes: 26 additions & 0 deletions quiz/part1/tugas4.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
/*
Soal 4
Diberikan sebuah function cariModus(arr) yang menerima sebuah array angka. Function akan me-return modus dari array atau deret angka tersebut. Modus adalah angka dari sebuah deret yang paling banyak atau paling sering muncul. Contoh, modus dari [10, 4, 5, 2, 4] adalah 4. Jika modus tidak ditemukan, function akan me-return -1. Apabila ditemukan lebih dari dua nilai modus, tampilkan nilai modus yang paling pertama muncul (dihitung dari kiri ke kanan). Dan apabila dialam modus hanya ada 1 nilai yang sama maka function akan me-return -1, Contohnya [1, 1, 1] adalah -1.
*/
function cariModus(arr) {
let arrModus = [], isSame = false;

for (let i = 0; i < arr.length; i++) {
for (let j = i + 1; j < arr.length; j++) {
if (arr[i] === arr[j]) {
isSame = true;
arrModus.push(arr[i]);
} else {
isSame = false;
}
}
}
return (arrModus[0] === undefined || isSame) ? -1 : arrModus[0];
}

// TEST CASES
console.log(cariModus([10, 4, 5, 2, 4])); // 4
console.log(cariModus([5, 10, 10, 6, 5])); // 5
console.log(cariModus([10, 3, 1, 2, 5])); // -1
console.log(cariModus([1, 2, 3, 3, 4, 5])); // 3
console.log(cariModus([7, 7, 7, 7, 7])); // -1