الفرق بين المراجعتين لصفحة: «Kotlin/collections/foldRightIndexed»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>foldRightIndexed()</code> في لغة Kotlin}}</noinclude> تُراكِم الدالة<code>foldRightIndexed()</code>...' |
جميل-بيلوني (نقاش | مساهمات) طلا ملخص تعديل |
||
(6 مراجعات متوسطة بواسطة 3 مستخدمين غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: الدالة <code>foldRightIndexed()</code> في | <noinclude>{{DISPLAYTITLE: الدالة <code>foldRightIndexed()</code> في Kotlin}}</noinclude> | ||
تجمع الدالة <code>foldRightIndexed()</code> ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. | |||
==البنية العامة== | ==البنية العامة== | ||
يمكن استدعاء الدالة<code> | يمكن استدعاء الدالة <code>foldRightIndexed()</code> مع [[Kotlin/Array|المصفوفات]]:<syntaxhighlight lang="kotlin"> | ||
inline fun <T, R> Array<out T>. | inline fun <T, R> Array<out T>.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, T, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> ByteArray. | inline fun <R> ByteArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Byte, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> ShortArray. | inline fun <R> ShortArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Short, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> IntArray. | inline fun <R> IntArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Int, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> LongArray. | inline fun <R> LongArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Long, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> FloatArray. | inline fun <R> FloatArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Float, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> DoubleArray. | inline fun <R> DoubleArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Double, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> BooleanArray. | inline fun <R> BooleanArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Boolean, acc: R) -> R | ||
): R | ): R | ||
inline fun <R> CharArray. | inline fun <R> CharArray.foldRightIndexed( | ||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, Char, acc: R) -> R | ||
): R | ): R | ||
</syntaxhighlight>ويمكن استدعاؤها مع [[Kotlin/collections|المجموعات]] أيضًا:<syntaxhighlight lang="kotlin"> | |||
</syntaxhighlight> | inline fun <T, R> List<T>.foldRightIndexed( | ||
inline fun <T, R> | |||
initial: R, | initial: R, | ||
operation: (index: Int, acc: R | operation: (index: Int, T, acc: R) -> R | ||
): R | ): R | ||
</syntaxhighlight> | </syntaxhighlight>وجود الكلمة المفتاحية <code>inline</code> يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة <nowiki/>[[Kotlin/inline functions|الدوال المباشرة (inline functions)]]). | ||
== | |||
ناتج تطبيق العملية | == المعاملات == | ||
=== <code>initial</code> === | |||
قيمة أولية يراد إضافتها مع ناتج تطبيق الدالة <code>operation</code> على أول عنصر من عناصر المصفوفة أو المجموعة المعطاة لبدء عملية التجميع. | |||
=== <code>operation</code> === | |||
دالةٌ تمثل العملية المراد تطبيقها على كل عنصر من عناصر المصفوفة أو المجموعة المعطاة، إذ يمرَّر إليها فهرس العنصر <code>index</code>، وقيمة كل عنصر من عناصر المصفوفة أو المجموعة المعطاة <code>T</code>، والقيمة المجمعة الحالية <code>acc</code>، ثم تعيد القيمة المجمَّعة <code>acc</code> التالية. | |||
==القيم المعادة== | |||
يعاد الناتج النهائي التراكمي لتطبيق العملية <code>operation</code> المعطاة على كل عنصر من عناصر [[Kotlin/Array|مصفوفة]] أو [[Kotlin/collections|مجموعة]] (بدءًا من اليمين إلى اليسار) مع فهرس ذلك العنصر مضافًا إليه القيمة الأولية <code>initial</code> إن أعطيت. | |||
==أمثلة== | ==أمثلة== | ||
تعرِّف الشيفرة الآتية <nowiki/>[[Kotlin/Array|مصفوفة]] باسم <code>array</code> باستخدام الدالة <code>()arrayOf</code>، ثم تستخدم الدالة <code>()foldRightIndexed</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. | val acc = array.foldRightIndexed(0) { acc, element, index -> acc + element * index } | ||
print(acc) // 719 | print(acc) // 719 | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==انظر أيضًا== | ==انظر أيضًا== | ||
<code>[[Kotlin/collections/ | * الدالة <code>[[Kotlin/collections/foldIndexed|foldIndexed()]]</code>: تجمع ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليسار إلى اليمين) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. | ||
* الدالة <code>[[Kotlin/collections/foldRight|foldRight()]]</code>: تجمع بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية بالإضافة إلى القيمة الأولية إن أعطيت. | |||
* الدالة <code>[[Kotlin/collections/reduceRightIndexed|reduceRightIndexed()]]</code>: تجمع الناتج التراكمي لتطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر والقيمة المجمَّعة الحالية. | |||
==مصادر== | ==مصادر== | ||
*[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/fold-indexed.html الدالة | *[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/fold-right-indexed.html صفحة الدالة foldRightIndexed() في التوثيق الرسميّ للمكتبة القياسيّة في لغة Kotlin.] | ||
[[تصنيف:Kotlin]] | [[تصنيف:Kotlin]] | ||
[[تصنيف:Kotlin | [[تصنيف:Kotlin Function]] | ||
[[تصنيف:Kotlin Collection]] |
المراجعة الحالية بتاريخ 08:11، 8 سبتمبر 2018
تجمع الدالة foldRightIndexed()
ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت.
البنية العامة
يمكن استدعاء الدالة foldRightIndexed()
مع المصفوفات:
inline fun <T, R> Array<out T>.foldRightIndexed(
initial: R,
operation: (index: Int, T, acc: R) -> R
): R
inline fun <R> ByteArray.foldRightIndexed(
initial: R,
operation: (index: Int, Byte, acc: R) -> R
): R
inline fun <R> ShortArray.foldRightIndexed(
initial: R,
operation: (index: Int, Short, acc: R) -> R
): R
inline fun <R> IntArray.foldRightIndexed(
initial: R,
operation: (index: Int, Int, acc: R) -> R
): R
inline fun <R> LongArray.foldRightIndexed(
initial: R,
operation: (index: Int, Long, acc: R) -> R
): R
inline fun <R> FloatArray.foldRightIndexed(
initial: R,
operation: (index: Int, Float, acc: R) -> R
): R
inline fun <R> DoubleArray.foldRightIndexed(
initial: R,
operation: (index: Int, Double, acc: R) -> R
): R
inline fun <R> BooleanArray.foldRightIndexed(
initial: R,
operation: (index: Int, Boolean, acc: R) -> R
): R
inline fun <R> CharArray.foldRightIndexed(
initial: R,
operation: (index: Int, Char, acc: R) -> R
): R
ويمكن استدعاؤها مع المجموعات أيضًا:
inline fun <T, R> List<T>.foldRightIndexed(
initial: R,
operation: (index: Int, T, acc: R) -> R
): R
وجود الكلمة المفتاحية inline
يدل على أنَّ هذه الدالة مباشرة (للمزيد من التفاصيل، راجع صفحة الدوال المباشرة (inline functions)).
المعاملات
initial
قيمة أولية يراد إضافتها مع ناتج تطبيق الدالة operation
على أول عنصر من عناصر المصفوفة أو المجموعة المعطاة لبدء عملية التجميع.
operation
دالةٌ تمثل العملية المراد تطبيقها على كل عنصر من عناصر المصفوفة أو المجموعة المعطاة، إذ يمرَّر إليها فهرس العنصر index
، وقيمة كل عنصر من عناصر المصفوفة أو المجموعة المعطاة T
، والقيمة المجمعة الحالية acc
، ثم تعيد القيمة المجمَّعة acc
التالية.
القيم المعادة
يعاد الناتج النهائي التراكمي لتطبيق العملية operation
المعطاة على كل عنصر من عناصر مصفوفة أو مجموعة (بدءًا من اليمين إلى اليسار) مع فهرس ذلك العنصر مضافًا إليه القيمة الأولية initial
إن أعطيت.
أمثلة
تعرِّف الشيفرة الآتية مصفوفة باسم array
باستخدام الدالة ()arrayOf
، ثم تستخدم الدالة ()foldRightIndexed
لجمع ناتج ضرب قيمة كل عنصر من عناصر تلك الصفوفة بفهرسه تراكميًّا:
fun main(args: Array<String>) {
val array = arrayOf(1, 2, 3, 4, 5, 6)
val acc = array.foldRightIndexed(0) { acc, element, index -> acc + element * index }
print(acc) // 719
}
انظر أيضًا
- الدالة
foldIndexed()
: تجمع ناتج تطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليسار إلى اليمين) المستدعاة معها وفهرس ذلك العنصر بشكل تراكمي بالإضافة إلى القيمة الأولية إن أعطيت. - الدالة
foldRight()
: تجمع بشكل تراكمي ناتج تطبيق عملية معيَّنة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها والقيمة التراكمية الحالية بالإضافة إلى القيمة الأولية إن أعطيت. - الدالة
reduceRightIndexed()
: تجمع الناتج التراكمي لتطبيق عملية معينة على قيمة كل عنصر من عناصر المصفوفة أو المجموعة (بدءًا من اليمين إلى اليسار) المستدعاة معها وفهرس ذلك العنصر والقيمة المجمَّعة الحالية.