--- title: Jaro distance id: 5a23c84252665b21eecc7ec2 localeTitle: 5a23c84252665b21eecc7ec2 challengeType: 5 --- ## Description
La distancia de Jaro es una medida de similitud entre dos cadenas. Cuanto mayor es la distancia de Jaro para dos cuerdas, más similares son las cuerdas. La puntuación se normaliza de modo que 0 equivale a ninguna similitud y 1 es una coincidencia exacta. Definición La distancia Jaro \ (d_j \) de dos cadenas dadas \ (s_1 \) y \ (s_2 \) es \ begin {align} d_j = \ begin {cases} 0 & & \ text {if} m = 0 \\ \\ {\ frac {1} {3}} \ left ({\ frac {m} {| s_ {1}}}} + {\ frac {m} {| s_ {2} |}} + {\ frac {mt} {m}} \ right) & & \ text {de lo contrario} \ end {cases} \ end {align} Donde: Dos caracteres de \ (s_1 \) y \ (s_2 \) respectivamente, se consideran coincidentes solo si son iguales y no están más lejos que \ (\ left \ lfloor \ frac {\ max (| s_1 |, | s_2 |) } {2} \ right \ rfloor-1 \). Cada carácter de \ (s_1 \) se compara con todos sus caracteres coincidentes en \ (s_2 \). El número de caracteres coincidentes (pero orden de secuencia diferente) dividido por 2 define el número de transposiciones . Ejemplo Dadas las cadenas \ (s_1 \) DWAYNE y \ (s_2 \) DUANE encontramos: Encontramos una puntuación Jaro de: \ (d_j = \ frac {1} {3} \ left (\ frac {4} {6} + \ frac {4} {5} + \ frac {4-0} {4 } \ right) = 0.822 \). Escriba una función a que tome dos cadenas como parámetros y devuelva la distancia Jaro asociada.
## Instructions
## Tests
```yml tests: - text: jaro debería ser una función. testString: 'assert(typeof jaro=="function","jaro should be a function.");' - text: jaro(""+tests[0][0]+"",""+tests[0][1]+"") debe devolver un número. testString: 'assert(typeof jaro(tests[0][0],tests[0][1])=="number","jaro() should return a number.");' - text: jaro(""+tests[0][0]+"",""+tests[0][1]+"") debe devolver "+results[0]+" . testString: 'assert.equal(jaro(tests[0][0],tests[0][1]),results[0],"jaro(""+tests[0][0]+"",""+tests[0][1]+"") should return "+results[0]+".");' - text: jaro(""+tests[1][0]+"",""+tests[1][1]+"") debe devolver "+results[1]+" . testString: 'assert.equal(jaro(tests[1][0],tests[1][1]),results[1],"jaro(""+tests[1][0]+"",""+tests[1][1]+"") should return "+results[1]+".");' - text: jaro(""+tests[2][0]+"",""+tests[2][1]+"") debe devolver "+results[2]+" . testString: 'assert.equal(jaro(tests[2][0],tests[2][1]),results[2],"jaro(""+tests[2][0]+"",""+tests[2][1]+"") should return "+results[2]+".");' - text: jaro(""+tests[3][0]+"",""+tests[3][1]+"") debe devolver "+results[3]+" . testString: 'assert.equal(jaro(tests[3][0],tests[3][1]),results[3],"jaro(""+tests[3][0]+"",""+tests[3][1]+"") should return "+results[3]+".");' - text: jaro(""+tests[4][0]+"",""+tests[4][1]+"") debe devolver "+results[4]+" . testString: 'assert.equal(jaro(tests[4][0],tests[4][1]),results[4],"jaro(""+tests[4][0]+"",""+tests[4][1]+"") should return "+results[4]+".");' ```
## Challenge Seed
```js function jaro (s, t) { // Good luck! } ```
### After Test
```js console.info('after the test'); ```
## Solution
```js function jaro (s, t) { var s_len = s.length; var t_len = t.length; if (s_len == 0 && t_len == 0) return 1; var match_distance = Math.max(s_len, t_len) / 2 - 1; var s_matches = new Array(s_len); var t_matches = new Array(t_len); var matches = 0; var transpositions = 0; for (var i = 0; i < s_len; i++) { var start = Math.max(0, i - match_distance); var end = Math.min(i + match_distance + 1, t_len); for (var j = start; j < end; j++) { if (t_matches[j]) continue; if (s.charAt(i) != t.charAt(j)) continue; s_matches[i] = true; t_matches[j] = true; matches++; break; } } if (matches == 0) return 0; var k = 0; for (var i = 0; i < s_len; i++) { if (!s_matches[i]) continue; while (!t_matches[k]) k++; if (s.charAt(i) != t.charAt(k)) transpositions++; k++; } return ((matches / s_len) + (matches / t_len) + ((matches - transpositions / 2.0) / matches)) / 3.0; } ```