Skip to content

Latest commit

 

History

History
46 lines (36 loc) · 1.8 KB

18-sistema.md

File metadata and controls

46 lines (36 loc) · 1.8 KB

El sistema operativo de Santa Claus

Evelyn Belefzin 👩‍💻 está trabajando en un sistema operativo para ser usado en el taller de Santa Claus 🎅.

Se ha dado cuenta que en el taller nadie le presta atención a los nombres de los ficheros y a veces intentan guardar el mismo fichero más de una vez... así que es importante que gestionemos bien los nombres duplicados.

Tenemos que crear una función que al pasarnos un array de nombres de archivo devolvamos un array con el mismo número de elementos pero donde los nombres que se repetían se anexe al final (k) donde k sería el número de veces que se encontró repetido.

Lo mejor es que veamos un ejemplo:

const files = ['photo', 'postcard', 'photo', 'photo', 'video']
fixFiles(files) // ['photo', 'postcard', 'photo(1)', 'photo(2)', 'video']

const files2 = ['file', 'file', 'file', 'game', 'game']
fixFiles(files2) = ['file', 'file(1)', 'file(2)', 'game', 'game(1)']

// ojo que los elfos ya tenían archivos con (1)... ¡y pueden estar repetidos!
const files3 = ['file', 'file(1)', 'icon', 'icon(1)', 'icon(1)']
fixFiles(files3) // ['file', 'file(1)', 'icon', 'icon(1)', 'icon(1)(1)']

Por cierto, nos han dicho que son Agile y usan Scrum. Por eso quieren saber cuánto tiempo vas a tardar para saber cuándo van a poder usarlo. Que hay prisa. 😝 Así que entra a Discord y cuéntanos.

Solución propuesta

function fixFiles(files) {
  let goodFiles = [],
    ayuda = {},
    fileName;
  for (let i = 0; i < files.length; i++) {
    if (ayuda[files[i]] != undefined) {
      fileName = files[i] + "(" + ayuda[files[i]] + ")";
      ayuda[files[i]]++;
    } else {
      ayuda[files[i]] = 1;
      fileName = files[i];
    }
    goodFiles.push(fileName);
  }
  return goodFiles;
}

Eso es todo, ¡Muchas gracias! 😎