การใช้ forEach Loop สร้างจำนวนเฉพาะใน Javascript ระหว่าง 1 ถึง 50 [ซ้ำกัน]
Aug 20 2020
นี่คือรหัสของฉัน แต่คำตอบของฉันไม่ใช่สิ่งที่ฉันต้องการ ..
โปรดตรวจสอบสิ่งนี้และให้วิธีแก้ปัญหาเพื่อรับจำนวนเฉพาะโดยใช้ Foreach Loop b / w 1-50
ขอบคุณล่วงหน้า :)
function isPrime(num) {
for ( var i = 2; i < num; i++ ) {
if ( num % i === 0 ) {
return false;
}
}
return true;
}
var txt = "";
function shown(n) {
var arr = [2];
arr.forEach(myFunction);
document.getElementById("foreach").innerHTML = txt;
// document.getElementById('forLoop').innerHTML = arr; // use arr result on your own
}
function myFunction(arr, index, array) {
var i;
var arr = [2];
if ( isPrime(i) ) {
arr.push(i);
}
txt += arr + "<br>";
}
shown(50);
คำตอบ
1 KoalaYeung Aug 20 2020 at 14:07
นี่อาจเป็นคำตอบขั้นสูงเกินไปสำหรับการบ้านในระดับนี้ แต่ในทางเทคนิคแล้วมันเป็นไปตามกฎ (ใช้ Array.forEach) และได้ผล
primes()
สร้างช่วงเวลาใหม่บนพื้นฐานของช่วงเวลาก่อนหน้านี้ ดังนั้นจะไม่ทดสอบการแจ้งเตือนของจำนวนเต็มทั้งหมดจึงมีประสิทธิภาพมากขึ้น มีการใช้ฟังก์ชันลูกศรหลายอย่างเพื่อให้สิ่งต่างๆสั้นลง หากคุณใช้คำตอบนี้จริงโปรดลองอ่านเอกสารที่เกี่ยวข้องและเรียนรู้:
- Iterators และ Generators
- นิพจน์ฟังก์ชันลูกศร
- สำหรับ ... จาก
- แม่แบบตัวอักษร
อย่างจริงจังพยายามคิดทีละขั้นตอน นั่นคือวิธีที่คุณเรียนรู้ทุกอย่าง
function* primes() {
const previous = [];
for (let i = 2; true; i++) {
let isPrime = true;
for (let p of previous) {
if (i % p === 0) {
isPrime = false;
break;
}
}
if (isPrime) {
previous.push(i);
yield i;
}
}
}
function* takeUntil(cb, iter) {
for (let val of iter) {
if (cb(val)) {
return;
}
yield val;
}
}
function showArrayIn(arr, container) {
arr.forEach(p => container.innerHTML += `${p},<br/>`); // technically, we used Array.forEach.
}
showArrayIn(
// get the prime number array declarativly
Array.from(takeUntil(n => n >= 50, primes())),
// show in the container specified
document.getElementById("results")
);
Primes:
<div id="results"></div>
NikhileshAgrawal Aug 20 2020 at 12:54
function primeFactorsTo(max)
{
var store = [], i, j, primes = [];
for (i = 2; i <= max; ++i)
{
if (!store [i])
{
primes.push(i);
for (j = i << 1; j <= max; j += i)
{
store[j] = true;
}
}
}
return primes;
}
console.log(primeFactorsTo(5));
console.log(primeFactorsTo(15));
raoabdullah07 Aug 20 2020 at 13:55
ฉันคิดว่านี่เป็นคำตอบที่ถูกต้องที่ฉันสมควรได้รับ .. มันเป็นคนรักรหัสที่สั้นและก้าวร้าว
function primes(limit)
{
var prime=[], i=1;
while (++i < limit+1) prime.reduce((a,c)=>(i%c)*a,1) && prime.push(i);
prime.unshift(2);
return prime;
}
[50].forEach(n=>document.getElementById('foreach').innerHTML=(`${primes(n)}`));
Twisty Aug 20 2020 at 12:54
ลองพิจารณาตัวอย่างต่อไปนี้
function isPrime(num) {
if (num === 1) {
return false;
} else if (num === 2) {
return true;
} else {
for (var x = 2; x < num; x++) {
if (num % x === 0) {
return false;
}
}
return true;
}
}
function shown(n) {
var list = [];
for (var i = 1; i <= n; i++) {
list.push(i);
}
list.slice().reverse().forEach(function(n, k, o) {
if (!isPrime(n)) {
list.splice(o.length - 1 - k, 1);
}
});
document.getElementById("show").innerHTML = list;
}
shown(50);
Prime: <p id="show"></p>