124 lines
6.7 KiB
Markdown
124 lines
6.7 KiB
Markdown
![]() |
---
|
|||
|
title: Sum All Odd Fibonacci Numbers
|
|||
|
localeTitle: Sum All Odd Fibonacci Numbers
|
|||
|
---
|
|||
|
 تذكر استخدام **`Read-Search-Ask`** إذا واجهتك مشكلة. حاول إقران البرنامج  واكتب الكود الخاص بك 
|
|||
|
|
|||
|
###  شرح المشكلة:
|
|||
|
|
|||
|
ستحتاج إلى جمع جميع أرقام **فيبوناتشي** ثم التحقق من الأرقام الفردية. بمجرد الحصول على تلك الغريب ثم ستضيف لهم جميعا. يجب أن يكون الرقم الأخير هو الرقم المعطى كمعلمة إذا كان في الواقع رقم إيقاف فيبوناتشي.
|
|||
|
|
|||
|
#### روابط ذات صلة
|
|||
|
|
|||
|
* [رقم فيبوناتشي](https://en.wikipedia.org/wiki/Fibonacci_number)
|
|||
|
|
|||
|
##  تلميح: 1
|
|||
|
|
|||
|
للحصول على العدد التالي من السلسلة ، تحتاج إلى إضافة الرقم الحالي إلى السلسلة السابقة والذي سيعطيك الخيار التالي.
|
|||
|
|
|||
|
> _حاول أن تحل المشكلة الآن_
|
|||
|
|
|||
|
##  تلميح: 2
|
|||
|
|
|||
|
لمعرفة ما إذا كان الرقم هو حتى كل ما عليك التحقق منه هو إذا كان `number % 2 == 0` .
|
|||
|
|
|||
|
> _حاول أن تحل المشكلة الآن_
|
|||
|
|
|||
|
##  تلميح: 3
|
|||
|
|
|||
|
عندما تحصل على الغريب القادم ، لا تنس أن تضيفه إلى متغير عالمي يمكن إرجاعه في النهاية. `result += currNumber;` سوف تفعل الخدعة.
|
|||
|
|
|||
|
> _حاول أن تحل المشكلة الآن_
|
|||
|
|
|||
|
## تنبيه المفسد!
|
|||
|
|
|||
|

|
|||
|
|
|||
|
**الحل في المستقبل!**
|
|||
|
|
|||
|
##  الحل الأساسي للكود:
|
|||
|
|
|||
|
`function sumFibs(num) {
|
|||
|
var prevNumber = 0;
|
|||
|
var currNumber = 1;
|
|||
|
var result = 0;
|
|||
|
while (currNumber <= num) {
|
|||
|
if (currNumber % 2 !== 0) {
|
|||
|
result += currNumber;
|
|||
|
}
|
|||
|
|
|||
|
currNumber += prevNumber;
|
|||
|
prevNumber = currNumber - prevNumber;
|
|||
|
}
|
|||
|
|
|||
|
return result;
|
|||
|
}
|
|||
|
|
|||
|
// test here
|
|||
|
sumFibs(4);
|
|||
|
`
|
|||
|
|
|||
|
 [تشغيل الكود](https://repl.it/CLnV/0)
|
|||
|
|
|||
|
### شرح الشفرة:
|
|||
|
|
|||
|
* إنشاء متغير للاحتفاظ بسجل للأرقام الحالية والسابقة بالإضافة إلى النتيجة التي سيتم إرجاعها.
|
|||
|
* استخدم حلقة while للتأكد من أننا لا نتجاوز الرقم المعطى كمعلمة.
|
|||
|
* نستخدم المعامل modulo للتحقق مما إذا كان الرقم الحالي فرديًا أو حتى. إذا كان موجودًا ، فقم بإضافته إلى النتيجة.
|
|||
|
* أكمل دائرة فيبوناتشي بالتناوب للحصول على الرقم التالي وقيم التبادل بعد.
|
|||
|
* العودة النتيجة.
|
|||
|
|
|||
|
#### روابط ذات صلة
|
|||
|
|
|||
|
* شبيبة أثناء حلقة
|
|||
|
|
|||
|
##  حل الشفرة المتوسطة:
|
|||
|
|
|||
|
`function sumFibs(num) {
|
|||
|
// Perform checks for the validity of the input
|
|||
|
if (num < 0) return -1;
|
|||
|
if (num === 0 || num === 1) return 1;
|
|||
|
|
|||
|
// Create an array of fib numbers till num
|
|||
|
const arrFib = [1, 1];
|
|||
|
let nextFib = 0;
|
|||
|
|
|||
|
// We put the new Fibonacci numbers to the front so we
|
|||
|
// don't need to calculate the length of the array on each
|
|||
|
// iteration
|
|||
|
while((nextFib = arrFib[0] + arrFib[1]) <= num) {
|
|||
|
arrFib.unshift(nextFib);
|
|||
|
}
|
|||
|
|
|||
|
// Sum only the odd numbers and return the value
|
|||
|
return arrFib.reduce((acc, curr) => {
|
|||
|
return acc + curr * (curr % 2);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
// test here
|
|||
|
sumFibs(4);
|
|||
|
`
|
|||
|
|
|||
|
 [تشغيل الكود](https://repl.it/@kr3at0/SumAllOddFibonacciNumbers)
|
|||
|
|
|||
|
### شرح الشفرة:
|
|||
|
|
|||
|
* إنشاء مجموعة من أرقام فيبوناتشي حتى **الأسطوانات** .
|
|||
|
* استخدم `reduce()` طريقة للعثور على مجموع أعضاء الصفيف الفردية.
|
|||
|
* أعد المبلغ.
|
|||
|
|
|||
|
#### روابط ذات صلة
|
|||
|
|
|||
|
* [JS Array Prototype Push](http://forum.freecodecamp.com/t/javascript-array-prototype-push/14298)
|
|||
|
* [شبيبة لشرح الحلقات](http://forum.freecodecamp.com/t/javascript-for-loop/14666s-Explained)
|
|||
|
* [JS Array Prototype Reduce](http://forum.freecodecamp.com/t/javascript-array-prototype-reduce/14299)
|
|||
|
|
|||
|
##  ملاحظات للمساهمات:
|
|||
|
|
|||
|
*  **لا تقم** بإضافة حلول مشابهة لأي حلول موجودة. إذا كنت تعتقد أنها **_مشابهة ولكن أفضل_** ، فحاول دمج (أو استبدال) الحل المشابه الموجود.
|
|||
|
* أضف شرحًا لحلك.
|
|||
|
* تصنيف الحل في واحدة من الفئات التالية - **الأساسي** **والمتوسط** **والمتقدم** . 
|
|||
|
* الرجاء إضافة اسم المستخدم الخاص بك فقط إذا قمت بإضافة أي **محتويات رئيسية ذات صلة** . (  **_لا_** _تزيل أي أسماء مستخدمين حالية_ )
|
|||
|
|
|||
|
> نرى  [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) كمرجع.
|