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