Sha256: eedbcab072c07b193f1e123710d73f1c81e8ebe63f2205eb0f97ace32406b95f

Contents?: true

Size: 451 Bytes

Versions: 116

Compression:

Stored size: 451 Bytes

Contents

object PascalsTriangle {

    fun computeTriangle(rows: Int): List<List<Int>> {
        require(rows >= 0, { "Rows can't be negative!" })

        if (rows == 0) return emptyList()
        return (1..rows).map { buildTriangleRow(it) }
    }

    private fun buildTriangleRow(row: Int): List<Int> {
        var m = 1
        return listOf(1) + (1 until row).map { col ->
            m = m * (row - col) / col
            return@map m
        }
    }
}

Version data entries

116 entries across 116 versions & 1 rubygems

Version Path
trackler-2.2.1.98 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.97 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.96 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.95 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.94 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.93 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.92 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.91 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.90 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.89 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.88 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.87 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.86 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.85 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.84 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.83 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.82 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.81 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.80 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt
trackler-2.2.1.79 tracks/kotlin/exercises/pascals-triangle/.meta/src/reference/kotlin/PascalsTriangle.kt