Revisions
-
trfiladelfo revised this gist
Jun 18, 2021 . 1 changed file with 7 additions and 13 deletions.There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,27 +1,21 @@ fun isCPF(document: String): Boolean { if (document.isEmpty()) return false val numbers = document.filter { it.isDigit() }.map { it.toString().toInt() } if (numbers.size != 11) return false //repeticao if (numbers.all { it == numbers[0] }) return false //digito 1 val dv1 = ((0..8).sumOf { (it + 1) * numbers[it] }).rem(11).let { if (it >= 10) 0 else it } val dv2 = ((0..8).sumOf { it * numbers[it] }.let { (it + (dv1 * 9)).rem(11) }).let { if (it >= 10) 0 else it } -
trfiladelfo revised this gist
Jul 12, 2018 . 1 changed file with 6 additions and 5 deletions.There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -17,11 +17,12 @@ fun isCPF(document: String): Boolean { } //digito 1 val dv1 = ((0..8).sumBy { (it + 1) * numbers[it] }).rem(11).let { if (it >= 10) 0 else it } val dv2 = ((0..8).sumBy { it * numbers[it] }.let { (it + (dv1 * 9)).rem(11) }).let { if (it >= 10) 0 else it } return numbers[9] == dv1 && numbers[10] == dv2 -
trfiladelfo revised this gist
May 8, 2018 . 1 changed file with 3 additions and 12 deletions.There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -17,21 +17,12 @@ fun isCPF(document: String): Boolean { } //digito 1 val dv1 = ((0..8).sumBy { (it + 1) * numbers[it] }).rem(11) //digito 2 val dv2 = (0..8).sumBy { it * numbers[it] }.let { (it + (dv1 * 9)).rem(11) } return numbers[9] == dv1 && numbers[10] == dv2 } -
trfiladelfo created this gist
May 4, 2018 .There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,37 @@ fun isCPF(document: String): Boolean { if (TextUtils.isEmpty(document)) return false val numbers = arrayListOf<Int>() document.filter { it.isDigit() }.forEach { numbers.add(it.toString().toInt()) } if (numbers.size != 11) return false //repeticao (0..9).forEach { n -> val digits = arrayListOf<Int>() (0..10).forEach { digits.add(n) } if (numbers == digits) return false } //digito 1 var dv1 = 0 (0..8).forEach { dv1 += ((it + 1) * numbers[it]) } dv1 = dv1.rem(11) //digito 2 var dv2 = 0 (0..8).forEach { dv2 += (it * numbers[it]) } dv2 += (dv1 * 9) dv2 = dv2.rem(11) return numbers[9] == dv1 && numbers[10] == dv2 }