الفرق بين المراجعتين لصفحة: «Kotlin/collections/foldRight»

من موسوعة حسوب
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>foldRight()‎</code> في لغة Kotlin}}</noinclude> تُراكِم الدالة<code>foldRight()‎</code> القيم ب...'
 
طلا ملخص تعديل
 
(5 مراجعات متوسطة بواسطة 3 مستخدمين غير معروضة)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE: الدالة <code>foldRight()‎</code> في لغة Kotlin}}</noinclude>
<noinclude>{{DISPLAYTITLE: الدالة <code>foldRight()‎</code> في Kotlin}}</noinclude>
تُراكِم الدالة<code>foldRight()‎</code> القيم بدءًا من القيمة المُمرّرة <code>initial</code> وتطبّق العملية <code>operation</code> من اليسار إلى اليمين على القيمة المُتراكمة الراهنة وعلى العنصر التالي من [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها وكذلك فهرسه. وتُعيد القيمة النهائية.  
تجمع الدالة <code>foldRight()‎</code> بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية بالإضافة إلى القيمة الأولية إن أعطيت. 
==البنية العامة==
==البنية العامة==
يمكن استدعاء الدالة<code>foldRight()‎</code> على [[Kotlin/Array|المصفوفات]].<syntaxhighlight lang="kotlin">
<syntaxhighlight lang="kotlin">
inline fun <T, R> Array<out T>.foldIndexed(
inline fun <T, R> Array<out T>.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, T) -> R
     operation: (T, acc: R) -> R
): R  
): R  
inline fun <R> ByteArray.foldIndexed(
inline fun <R> ByteArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Byte) -> R
     operation: (Byte, acc: R) -> R
): R  
): R  
inline fun <R> ShortArray.foldIndexed(
inline fun <R> ShortArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Short) -> R
     operation: (Short, acc: R) -> R
): R  
): R  
inline fun <R> IntArray.foldIndexed(
inline fun <R> IntArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Int) -> R
     operation: (Int, acc: R) -> R
): R  
): R  
inline fun <R> LongArray.foldIndexed(
inline fun <R> LongArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Long) -> R
     operation: (Long, acc: R) -> R
): R  
): R  
inline fun <R> FloatArray.foldIndexed(
inline fun <R> FloatArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Float) -> R
     operation: (Float, acc: R) -> R
): R  
): R  
inline fun <R> DoubleArray.foldIndexed(
inline fun <R> DoubleArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Double) -> R
     operation: (Double, acc: R) -> R
): R  
): R  
inline fun <R> BooleanArray.foldIndexed(
inline fun <R> BooleanArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Boolean) -> R
     operation: (Boolean, acc: R) -> R
): R  
): R  
inline fun <R> CharArray.foldIndexed(
inline fun <R> CharArray.foldRight(
     initial: R,  
     initial: R,  
     operation: (index: Int, acc: R, Char) -> R
     operation: (Char, acc: R) -> R
): R  
): R  
inline fun <T, R> List<T>.foldRight(
    initial: R,
    operation: (T, acc: R) -> R
): R
</syntaxhighlight><nowiki/>وجود الكلمة المفتاحية <code>inline</code> يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة <nowiki/>[[Kotlin/inline functions|الدوال المباشرة (inline functions)]]).
== المعاملات ==
=== <code>initial</code> ===
قيمة أولية يراد إضافتها مع ناتج تطبيق الدالة <code>operation</code> على أول عنصر من عناصر المصفوفة أو المجموعة لبدء عملية التجميع.


</syntaxhighlight>يمكن استدعاء غلدالة<code>foldRight()‎</code> على [[Kotlin/Array|المجموعات]].<syntaxhighlight lang="kotlin">
=== <code>operation</code> ===
inline fun <T, R> Iterable<T>.foldIndexed(
دالةٌ تمثل العملية المراد تطبيقها على كل عنصر من عناصر المصفوفة أو المجموعة، إذ يمرَّر إليها القيمة المجمعة الحالية <code>acc</code> وقيمة كل عنصر من عناصر المصفوفة أو المجموعة <code>T</code>، ثم تعيد القيمة المجمَّعة التالية <code>acc</code>.
    initial: R,
 
    operation: (index: Int, acc: R, T) -> R
==القيم المعادة==
): R
يعاد الناتج النهائي التراكمي لتطبيق العملية <code>operation</code> المعطاة على كل عنصر من عناصر [[Kotlin/Array|مصفوفة]] أو [[Kotlin/collections|مجموعة]] (بدءًا من اليمين إلى اليسار) مع فهرس ذلك العنصر مضافًا إليه القيمة الأولية <code>initial</code> إن أعطيت. 
</syntaxhighlight>يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
==القيم المٌعادة==
ناتج تطبيق العملية المُمرّرة <code>operation</code> تراكميًا على عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها وكذلك فهارسها.  
==أمثلة==
==أمثلة==
===استخدام الدالة <code>()foldRight</code> مع المصفوفات===
تعرِّف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> باستخدام الدالة <code>()arrayOf</code> ثمَّ تستخدم الدالة <code>()foldRight</code> لجمع قيم عناصرها بشكل تراكمي:<syntaxhighlight lang="kotlin">
تعرف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> مكونة من ستة أعداد باستخدام الدالة <code>()arrayOf</code>، ثم تستخدم الدالة <code>()foldRight</code> على <code>array</code> بتمرير القيمة الأوّلية <code>0</code> إضافة إلى عملية تُضيف القيمة المتراكمة الراهنة إلى حاصل ضرب عناصر <code>array</code> في فهارسها، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
val array = arrayOf(1,2,3,4,5,6)
    val array = arrayOf(1, 2, 3, 4, 5, 6)


val acc = array.foldIndexed(0) { acc , element , index -> acc + element*index }
    val acc = array.foldRight(0) { acc, element -> acc + element }
print(acc) // 719
    print(acc) // 21
}
}
</syntaxhighlight>
</syntaxhighlight>
==انظر أيضًا==
==انظر أيضًا==
* صفحة الدالة<code>[[Kotlin/collections/find|foldIndexed()]]</code>‎
* الدالة <code>[[Kotlin/collections/foldRightIndexed|foldRightIndexed()]]</code>: تجمع ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. 
* الدالة <code>[[Kotlin/collections/reduceRight|reduceRight()]]</code>: تجمع بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية. 


==مصادر==
==مصادر==
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/fold-indexed.html الدالة  foldRight()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/fold-right.html صفحة الدالة foldRight()‎ في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin Functions]]
[[تصنيف:Kotlin Function]]
[[تصنيف:Kotlin Collection]]

المراجعة الحالية بتاريخ 08:10، 8 سبتمبر 2018

تجمع الدالة foldRight()‎ بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية بالإضافة إلى القيمة الأولية إن أعطيت. 

البنية العامة

inline fun <T, R> Array<out T>.foldRight(
    initial: R, 
    operation: (T, acc: R) -> R
): R 
inline fun <R> ByteArray.foldRight(
    initial: R, 
    operation: (Byte, acc: R) -> R
): R 
inline fun <R> ShortArray.foldRight(
    initial: R, 
    operation: (Short, acc: R) -> R
): R 
inline fun <R> IntArray.foldRight(
    initial: R, 
    operation: (Int, acc: R) -> R
): R 
inline fun <R> LongArray.foldRight(
    initial: R, 
    operation: (Long, acc: R) -> R
): R 
inline fun <R> FloatArray.foldRight(
    initial: R, 
    operation: (Float, acc: R) -> R
): R 
inline fun <R> DoubleArray.foldRight(
    initial: R, 
    operation: (Double, acc: R) -> R
): R 
inline fun <R> BooleanArray.foldRight(
    initial: R, 
    operation: (Boolean, acc: R) -> R
): R 
inline fun <R> CharArray.foldRight(
    initial: R, 
    operation: (Char, acc: R) -> R
): R 
inline fun <T, R> List<T>.foldRight(
    initial: R, 
    operation: (T, acc: R) -> R
): R

وجود الكلمة المفتاحية inline يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة الدوال المباشرة (inline functions)).

المعاملات

initial

قيمة أولية يراد إضافتها مع ناتج تطبيق الدالة operation على أول عنصر من عناصر المصفوفة أو المجموعة لبدء عملية التجميع.

operation

دالةٌ تمثل العملية المراد تطبيقها على كل عنصر من عناصر المصفوفة أو المجموعة، إذ يمرَّر إليها القيمة المجمعة الحالية acc وقيمة كل عنصر من عناصر المصفوفة أو المجموعة T، ثم تعيد القيمة المجمَّعة التالية acc.

القيم المعادة

يعاد الناتج النهائي التراكمي لتطبيق العملية operation المعطاة على كل عنصر من عناصر مصفوفة أو مجموعة (بدءًا من اليمين إلى اليسار) مع فهرس ذلك العنصر مضافًا إليه القيمة الأولية initial إن أعطيت. 

أمثلة

تعرِّف الشيفرة الآتية مصفوفة باسم array باستخدام الدالة ()arrayOf ثمَّ تستخدم الدالة ()foldRight لجمع قيم عناصرها بشكل تراكمي:

fun main(args: Array<String>) {
    val array = arrayOf(1, 2, 3, 4, 5, 6)

    val acc = array.foldRight(0) { acc, element -> acc + element }
    print(acc) // 21
}

انظر أيضًا

  • الدالة foldRightIndexed()‎: تجمع ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. 
  • الدالة reduceRight()‎: تجمع بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية. 

مصادر