File: functional.cj

package info (click to toggle)
cloc 2.06-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 8,064 kB
  • sloc: perl: 30,146; cpp: 1,219; python: 623; ansic: 334; asm: 267; makefile: 244; sh: 186; sql: 144; java: 136; ruby: 111; cs: 104; pascal: 52; lisp: 50; haskell: 35; f90: 35; cobol: 35; objc: 25; php: 22; javascript: 15; fortran: 9; ml: 8; xml: 7; tcl: 2
file content (60 lines) | stat: -rw-r--r-- 1,457 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*
https://github.com/Zxilly/playground-cj/blob/master/src/examples/functional.cj
*/
package playground

// 用给定的分隔符拆分字符串,支持多分隔符
import std.collection.*

// 常规实现
func split_normal(text: String, sep: String): ArrayList<String> {
    let indices = ArrayList<Int64>()
    var last = true
    for (i in 0..text.size) {
        let current = sep.indexOf(text[i]).isSome()
        if (last != current) {
            indices.add(i)
        }
        last = current
    }
    if (!last) {
        indices.add(text.size)
    }

    let result = ArrayList<String>()
    for (i in 0..indices.size : 2) {
        result.add(text[indices[i]..indices[i + 1]])
    }
    return result
}

// 函数式编程实现
func split(text: String, sep: String): ArrayList<String> {
    let indices = ArrayList<Int64>()
    text |> enumerate |>
        fold(false) {
        state, e =>
        let current = sep.indexOf(e[1]).isNone()
        if (state != current) {
            indices.add(e[0])
        }
        current
    } |> {
        valid: Bool => if (valid) {
            indices.add(text.size)
        }
    }

    let result = ArrayList<String>()
    for (i in 0..indices.size : 2) {
        result.add(text[indices[i]..indices[i + 1]])
    }
    return result
}

main() {
    let text = "123, 456 7&89, , 96^3, 567"
    let separator = "&^, "
    println(split_normal(text, separator))
    println(split(text, separator))
}