-
-
Save f3llps/a5ff113a1af644286d3cf5ae8eb367e7 to your computer and use it in GitHub Desktop.
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 hidden or 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 hidden or 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 hidden or 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 hidden or 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 }