Hola a todos,
quizás esto pueda ser útil para algunas personas...
La proporción de números en el vector que son mayores, menores o iguales a 0:
const NumberValue = {
GREATER_THAN_0: i => i > 0,
LESS_THAN_0: i => i < 0,
EQUAL_TO_0: i => i == 0
};
function printStatistics(...a) {
for (var key in NumberValue) {
if (NumberValue.hasOwnProperty(key)) {
console.log(key + " = " + sum(NumberValue[key],a).map(i => 1.0 / a.length).reduce((pv, cv) => pv + cv, 0));
}
}
}
function sum(callback, a) {
return a.filter(callback);
}
console.log(printStatistics(-5, 5, 4, 3, 2, 1, 0, -1));
Resultado:
GREATER_THAN_0 = 0.625
LESS_THAN_0 = 0.25
EQUAL_TO_0 = 0.125
Saludos
Mod Edit: Usar etiquetas GeSHI.
Qué recuerdos del colegio. Ahí va mi forma de hacerlo:
let proporcion = (...nums) => {
let greater, less = 0, equal = 0;
for(let i in nums) {
nums[i] < 0 && ++less;
nums[i] == 0 && ++equal;
}
greater = ( nums.length - (less + equal) ) / nums.length;
less /= nums.length;
equal /= nums.length;
return [greater, less, equal];
}
alert(proporcion(-5, 5, 4, 3, 2, 1, 0, -1));
Un poco más de golf pero se puede leer bien yo creo:
let proporcion = (...arr) => {
let porcentaje = 1/arr.length;
return arr.reduce((total, actual) => (
actual > 0
? total.mayor += porcentaje
: actual < 0
? total.menor += porcentaje
: total.igual += porcentaje,
total),
{ mayor: 0, menor: 0, igual: 0});
};
Cita de: MinusFour en 9 Enero 2021, 02:35 AM
Un poco más de golf pero se puede leer bien yo creo:
let proporcion = (...arr) => {
let porcentaje = 1/arr.length;
return arr.reduce((total, actual) => (
actual > 0
? total.mayor += porcentaje
: actual < 0
? total.menor += porcentaje
: total.igual += porcentaje,
total),
{ mayor: 0, menor: 0, igual: 0});
};
Si a tu código le agrego
console.log(proporcion(-5, 5, 4, 3, 2, 1, 0, -1));
entonces, en vez de mostrarme los resultados esperados, me muestra:
Citar[object Object]
Entonces tu console.log está haciendo algo diferente a los demás. Por lo general console.log imprime la estructura del objeto no su valor primitivo.
(https://i.imgur.com/mpzL78Z.png)
Una versión aún más reducida pero creo que no se lee tan bien.
let proporcion = (...arr) => {
let porcentaje = 1/arr.length;
return arr.reduce((total, actual) => (
total[actual > 0
? 'mayor'
: actual < 0
? 'menor'
: 'igual'
] += porcentaje,
total),
{ mayor: 0, menor: 0, igual: 0});
};
Cita de: MinusFour en 13 Enero 2021, 17:44 PM
Entonces tu console.log está haciendo algo diferente a los demás. Por lo general console.log imprime la estructura del objeto no su valor primitivo.
No es solamente el console.log, también la función alert me larga lo mismo.
Yo uso Chrome. Supongo que vos usas Firefox.
CitarNo es solamente el console.log, también la función alert me larga lo mismo.
El alert no tiene capacidad de mostrar estructuras. Solo puede mostrar valores convertibles a string. El console log en Chrome si deberia funcionar sin ningun problema, a mi me funciona bien. Ten en cuenta que no puedes concatenar cosas a la respuesta de un objeto. Por ejemplo esto no seria valido:
console.log('resultado: ' + proporcion(-5, 5));
Saludos