Kotlin - Backfill
This commit is contained in:
parent
2848b5e833
commit
61683c383f
12 changed files with 418 additions and 0 deletions
13
kotlin/bracket-push/README.md
Normal file
13
kotlin/bracket-push/README.md
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
# Bracket Push
|
||||||
|
|
||||||
|
Given a string containing brackets `[]`, braces `{}` and parentheses `()`,
|
||||||
|
verify that all the pairs are matched and nested correctly.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Source
|
||||||
|
|
||||||
|
Ginna Baker
|
||||||
|
|
||||||
|
## Submitting Incomplete Solutions
|
||||||
|
It's possible to submit an incomplete solution so you can see how others have completed the exercise.
|
28
kotlin/bracket-push/build.gradle
Normal file
28
kotlin/bracket-push/build.gradle
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
buildscript {
|
||||||
|
ext.kotlin_version = '1.1.1'
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
apply plugin: 'kotlin'
|
||||||
|
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||||
|
|
||||||
|
testCompile 'junit:junit:4.12'
|
||||||
|
testCompile "org.jetbrains.kotlin:kotlin-test-junit:$kotlin_version"
|
||||||
|
}
|
||||||
|
test {
|
||||||
|
testLogging {
|
||||||
|
exceptionFormat = 'full'
|
||||||
|
events = ["passed", "failed", "skipped"]
|
||||||
|
}
|
||||||
|
}
|
35
kotlin/bracket-push/src/test/kotlin/BracketPushTest.kt
Normal file
35
kotlin/bracket-push/src/test/kotlin/BracketPushTest.kt
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
|
||||||
|
import org.junit.Test
|
||||||
|
import org.junit.Ignore
|
||||||
|
import org.junit.runner.RunWith
|
||||||
|
import org.junit.runners.Parameterized
|
||||||
|
import kotlin.test.assertEquals
|
||||||
|
|
||||||
|
@RunWith(Parameterized::class)
|
||||||
|
class BracketPushTest(val input: String, val expectedOutput: Boolean) {
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
@JvmStatic
|
||||||
|
@Parameterized.Parameters(name = "{index}: bracket({0})={1}")
|
||||||
|
fun data() = listOf(
|
||||||
|
arrayOf("[]", true),
|
||||||
|
arrayOf("", true),
|
||||||
|
arrayOf("[[", false),
|
||||||
|
arrayOf("}{", false),
|
||||||
|
arrayOf("{ }", true),
|
||||||
|
arrayOf("{[]}", true),
|
||||||
|
arrayOf("{}[]", true),
|
||||||
|
arrayOf("([{}({}[])])", true),
|
||||||
|
arrayOf("([{])", false),
|
||||||
|
arrayOf("[({]})", false),
|
||||||
|
arrayOf("(((185 + 223.85) * 15) - 543)/2", true),
|
||||||
|
arrayOf("\\\\left(\\\\begin{array}{cc} \\\\frac{1}{3} & x\\\\\\\\ \\\\mathrm{e}^{x} &... x^2 \\\\end{array}\\\\right)", true)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun test() {
|
||||||
|
assertEquals(expectedOutput, BracketPush.isValid(input))
|
||||||
|
}
|
||||||
|
}
|
24
kotlin/pascals-triangle/README.md
Normal file
24
kotlin/pascals-triangle/README.md
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
# Pascals Triangle
|
||||||
|
|
||||||
|
Compute Pascal's triangle up to a given number of rows.
|
||||||
|
|
||||||
|
In Pascal's Triangle each number is computed by adding the numbers to
|
||||||
|
the right and left of the current position in the previous row.
|
||||||
|
|
||||||
|
```plain
|
||||||
|
1
|
||||||
|
1 1
|
||||||
|
1 2 1
|
||||||
|
1 3 3 1
|
||||||
|
1 4 6 4 1
|
||||||
|
# ... etc
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Source
|
||||||
|
|
||||||
|
Pascal's Triangle at Wolfram Math World [http://mathworld.wolfram.com/PascalsTriangle.html](http://mathworld.wolfram.com/PascalsTriangle.html)
|
||||||
|
|
||||||
|
## Submitting Incomplete Solutions
|
||||||
|
It's possible to submit an incomplete solution so you can see how others have completed the exercise.
|
28
kotlin/pascals-triangle/build.gradle
Normal file
28
kotlin/pascals-triangle/build.gradle
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
buildscript {
|
||||||
|
ext.kotlin_version = '1.1.1'
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
apply plugin: 'kotlin'
|
||||||
|
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||||
|
|
||||||
|
testCompile 'junit:junit:4.12'
|
||||||
|
testCompile "org.jetbrains.kotlin:kotlin-test-junit:$kotlin_version"
|
||||||
|
}
|
||||||
|
test {
|
||||||
|
testLogging {
|
||||||
|
exceptionFormat = 'full'
|
||||||
|
events = ["passed", "failed", "skipped"]
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
import org.junit.Test
|
||||||
|
import org.junit.Ignore
|
||||||
|
import kotlin.test.assertEquals
|
||||||
|
|
||||||
|
class PascalsTriangleTest {
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun triangleWithFourRows() {
|
||||||
|
val expectedOutput = listOf(
|
||||||
|
listOf(1),
|
||||||
|
listOf(1, 1),
|
||||||
|
listOf(1, 2, 1),
|
||||||
|
listOf(1, 3, 3, 1)
|
||||||
|
)
|
||||||
|
|
||||||
|
assertEquals(expectedOutput, PascalsTriangle.computeTriangle(4))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun triangleWithSixRows() {
|
||||||
|
val expectedOutput = listOf(
|
||||||
|
listOf(1),
|
||||||
|
listOf(1, 1),
|
||||||
|
listOf(1, 2, 1),
|
||||||
|
listOf(1, 3, 3, 1),
|
||||||
|
listOf(1, 4, 6, 4, 1),
|
||||||
|
listOf(1, 5, 10, 10, 5, 1)
|
||||||
|
)
|
||||||
|
|
||||||
|
assertEquals(expectedOutput, PascalsTriangle.computeTriangle(6))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun expectEmptyTriangle() {
|
||||||
|
val expectedOutput = emptyList<List<Int>>()
|
||||||
|
|
||||||
|
assertEquals(expectedOutput, PascalsTriangle.computeTriangle(0))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test(expected = IllegalArgumentException::class)
|
||||||
|
fun validatesNotNegativeRows() {
|
||||||
|
PascalsTriangle.computeTriangle(-1)
|
||||||
|
}
|
||||||
|
}
|
39
kotlin/rotational-cipher/README.md
Normal file
39
kotlin/rotational-cipher/README.md
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
# Rotational Cipher
|
||||||
|
|
||||||
|
Create an implementation of the rotational cipher, also sometimes called the Caesar cipher.
|
||||||
|
|
||||||
|
The Caesar cipher is a simple shift cipher that relies on
|
||||||
|
transposing all the letters in the alphabet using an integer key
|
||||||
|
between `0` and `26`. Using a key of `0` or `26` will always yield
|
||||||
|
the same output due to modular arithmetic. The letter is shifted
|
||||||
|
for as many values as the value of the key.
|
||||||
|
|
||||||
|
The general notation for rotational ciphers is `ROT + <key>`.
|
||||||
|
The most commonly used rotational cipher is `ROT13`.
|
||||||
|
|
||||||
|
A `ROT13` on the Latin alphabet would be as follows:
|
||||||
|
|
||||||
|
```plain
|
||||||
|
Plain: abcdefghijklmnopqrstuvwxyz
|
||||||
|
Cipher: nopqrstuvwxyzabcdefghijklm
|
||||||
|
```
|
||||||
|
|
||||||
|
It is stronger than the Atbash cipher because it has 27 possible keys, and 25 usable keys.
|
||||||
|
|
||||||
|
Ciphertext is written out in the same formatting as the input including spaces and punctuation.
|
||||||
|
|
||||||
|
## Examples
|
||||||
|
- ROT5 `omg` gives `trl`
|
||||||
|
- ROT0 `c` gives `c`
|
||||||
|
- ROT26 `Cool` gives `Cool`
|
||||||
|
- ROT13 `The quick brown fox jumps over the lazy dog.` gives `Gur dhvpx oebja sbk whzcf bire gur ynml qbt.`
|
||||||
|
- ROT13 `Gur dhvpx oebja sbk whzcf bire gur ynml qbt.` gives `The quick brown fox jumps over the lazy dog.`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Source
|
||||||
|
|
||||||
|
Wikipedia [https://en.wikipedia.org/wiki/Caesar_cipher](https://en.wikipedia.org/wiki/Caesar_cipher)
|
||||||
|
|
||||||
|
## Submitting Incomplete Solutions
|
||||||
|
It's possible to submit an incomplete solution so you can see how others have completed the exercise.
|
28
kotlin/rotational-cipher/build.gradle
Normal file
28
kotlin/rotational-cipher/build.gradle
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
buildscript {
|
||||||
|
ext.kotlin_version = '1.1.1'
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
apply plugin: 'kotlin'
|
||||||
|
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||||
|
|
||||||
|
testCompile 'junit:junit:4.12'
|
||||||
|
testCompile "org.jetbrains.kotlin:kotlin-test-junit:$kotlin_version"
|
||||||
|
}
|
||||||
|
test {
|
||||||
|
testLogging {
|
||||||
|
exceptionFormat = 'full'
|
||||||
|
events = ["passed", "failed", "skipped"]
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,81 @@
|
||||||
|
import org.junit.Ignore
|
||||||
|
import org.junit.Test
|
||||||
|
import kotlin.test.assertEquals
|
||||||
|
|
||||||
|
/*
|
||||||
|
* version: 1.0.0
|
||||||
|
*/
|
||||||
|
class RotationalCipherTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testRotateLowercaseABy1NoWrapAround() {
|
||||||
|
val cipher = RotationalCipher(1)
|
||||||
|
assertEquals("b", cipher.encode("a"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testRotateLowercaseABy26SingleWrapAround() {
|
||||||
|
val cipher = RotationalCipher(26)
|
||||||
|
assertEquals("a", cipher.encode("a"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testRotateLowercaseABy0() {
|
||||||
|
val cipher = RotationalCipher(0)
|
||||||
|
assertEquals("a", cipher.encode("a"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testRotateLowercaseMBy13NoWrapAround() {
|
||||||
|
val cipher = RotationalCipher(13)
|
||||||
|
assertEquals("z", cipher.encode("m"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testRotateLowercaseNBy1SingleWrapAround() {
|
||||||
|
val cipher = RotationalCipher(13)
|
||||||
|
assertEquals("a", cipher.encode("n"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testRotateCapitalLettersNoWrapAround() {
|
||||||
|
val cipher = RotationalCipher(5)
|
||||||
|
assertEquals("TRL", cipher.encode("OMG"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testSpacesAreUnalteredByRotation() {
|
||||||
|
val cipher = RotationalCipher(5)
|
||||||
|
assertEquals("T R L", cipher.encode("O M G"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testNumbersAreUnalteredByRotation() {
|
||||||
|
val cipher = RotationalCipher(4)
|
||||||
|
assertEquals("Xiwxmrk 1 2 3 xiwxmrk", cipher.encode("Testing 1 2 3 testing"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testPunctuationIsUnalteredByRotation() {
|
||||||
|
val cipher = RotationalCipher(21)
|
||||||
|
assertEquals("Gzo'n zvo, Bmviyhv!", cipher.encode("Let's eat, Grandma!"))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testAllLettersRotateCorrectly() {
|
||||||
|
val cipher = RotationalCipher(13)
|
||||||
|
assertEquals(
|
||||||
|
"Gur dhvpx oebja sbk whzcf bire gur ynml qbt.",
|
||||||
|
cipher.encode("The quick brown fox jumps over the lazy dog."))
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
30
kotlin/series/README.md
Normal file
30
kotlin/series/README.md
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
# Series
|
||||||
|
|
||||||
|
Given a string of digits, output all the contiguous substrings of length `n` in
|
||||||
|
that string.
|
||||||
|
|
||||||
|
For example, the string "49142" has the following 3-digit series:
|
||||||
|
|
||||||
|
- 491
|
||||||
|
- 914
|
||||||
|
- 142
|
||||||
|
|
||||||
|
And the following 4-digit series:
|
||||||
|
|
||||||
|
- 4914
|
||||||
|
- 9142
|
||||||
|
|
||||||
|
And if you ask for a 6-digit series from a 5-digit string, you deserve
|
||||||
|
whatever you get.
|
||||||
|
|
||||||
|
Note that these series are only required to occupy *adjacent positions*
|
||||||
|
in the input; the digits need not be *numerically consecutive*.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Source
|
||||||
|
|
||||||
|
A subset of the Problem 8 at Project Euler [http://projecteuler.net/problem=8](http://projecteuler.net/problem=8)
|
||||||
|
|
||||||
|
## Submitting Incomplete Solutions
|
||||||
|
It's possible to submit an incomplete solution so you can see how others have completed the exercise.
|
28
kotlin/series/build.gradle
Normal file
28
kotlin/series/build.gradle
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
buildscript {
|
||||||
|
ext.kotlin_version = '1.1.1'
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
apply plugin: 'kotlin'
|
||||||
|
|
||||||
|
repositories {
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||||
|
|
||||||
|
testCompile 'junit:junit:4.12'
|
||||||
|
testCompile "org.jetbrains.kotlin:kotlin-test-junit:$kotlin_version"
|
||||||
|
}
|
||||||
|
test {
|
||||||
|
testLogging {
|
||||||
|
exceptionFormat = 'full'
|
||||||
|
events = ["passed", "failed", "skipped"]
|
||||||
|
}
|
||||||
|
}
|
36
kotlin/series/src/test/kotlin/SeriesTest.kt
Normal file
36
kotlin/series/src/test/kotlin/SeriesTest.kt
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
import org.junit.Test
|
||||||
|
import org.junit.Ignore
|
||||||
|
import kotlin.test.assertEquals
|
||||||
|
|
||||||
|
class SeriesTest {
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun slicesOfOne() {
|
||||||
|
assertEquals(listOf<List<Int>>(), Series.slices(1, ""))
|
||||||
|
assertEquals(
|
||||||
|
listOf(listOf(0), listOf(1), listOf(2), listOf(3), listOf(4)),
|
||||||
|
Series.slices(1, "01234")
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun slicesOfTwo() {
|
||||||
|
assertEquals(listOf<List<Int>>(), Series.slices(2, ""))
|
||||||
|
assertEquals(listOf(listOf(0, 1)), Series.slices(2, "01"))
|
||||||
|
assertEquals(
|
||||||
|
listOf(listOf(0, 1), listOf(1, 2), listOf(2, 3), listOf(3, 4)),
|
||||||
|
Series.slices(2, "01234")
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun slicesOfThree() {
|
||||||
|
assertEquals(listOf<List<Int>>(), Series.slices(3, ""))
|
||||||
|
assertEquals(listOf(listOf(0, 1, 2)), Series.slices(3, "012"))
|
||||||
|
assertEquals(
|
||||||
|
listOf(listOf(0, 1, 2), listOf(1, 2, 3), listOf(2, 3, 4)),
|
||||||
|
Series.slices(3, "01234")
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue