[5kyu]Basic Nico variation

该算法题来自于 codewars【语言: javascript】,翻译如有误差,敬请谅解~

  • 任务
  • 写一个接收两个参数的函数nico,使用keymsg编码
    key:由唯一的字母和数字组成
    msg: 要编码的字符串
  • 规则:首先根据提供的key创建一个数字键,方法是按字母顺序对key中的数字和字母进行排序。
  • 例如:
    对于当keycrazy时,因为将crazy排序后得到acryz,那么crazy编码后即为23154,然后再使用crazy来编码msg
    2 3 1 5 4
    ---------
    s e c r e
    t i n f o
    r m a t i
    o n
    编码之后为:
    1 2 3 4 5
    ---------
    c s e e r
    n t i o f
    a r m i t
    o n
  • 注意:msg的长度不会比key
  • 例如:
    nico("crazy", "secretinformation") // "cseerntiofarmit on "
    nico("abc", "abcd") // "abcd "
    nico("ba", "1234567890") // "2143658709"
    nico("key", "key") // "eky"

  • 解答
  • 其一
function nico  (key, msg)  {
      let sortNum = [...key].sort();
      let arr = [...key].map(el => {
        return {k: el,n: sortNum.indexOf(el)+1}             
      });  
      // 根据key截取msg
      let strArr = [];
      for (let i=0;i < Math.floor(msg.length/key.length) +  (msg.length%key.length ? 1 : 0);i++) {
        strArr.push(msg.slice(key.length*i,key.length*(i+1)))
      }  
      // msg数组内排序
      strArr = strArr.map((el,index)=>{
        let msgArr = [];
        for (let i=0;i < [...el].length;i++) {
          msgArr.push({k: [...el][i],n: arr[i].n})
        }
        msgArr = msgArr.sort((a, b) => a.n - b.n);
        // 处理最后一个元素
        if (index == strArr.length-1 && key.length != el.length) {
          msgArr = [...key].map((el,index) => {
            let obj = {k:' ',n:index+1};
            for (let j=0;j<msgArr.length;j++) {
              if (index+1 == msgArr[j].n) {
                obj.k = msgArr[j].k;
              }
            }
          })
        }           
        return msgArr.map(obj => obj.k).join('');
      });
      return strArr.join('');
}
  • 其二
function nico(key, message) {
      const order = Array.from( key, (_,i) => i ).sort( (v,w) => Number(key[v]>key[w]) - Number(key[v]<key[w]) );
      return ( message + " ".repeat(key.length-1) ).match( new RegExp( `.{${key.length}}`, "g" ) ).map( s => order.map( i => s[i] ).join("") ).join("");
}
  • 其三
function nico (key, message) {
      var numericKey = Array.from(key).sort().map(letter => key.indexOf(letter));
      var encoded = [];
      for (var i = 0; i < message.length / key.length; i++) {
          encoded[i*key.length + j] = message[i*key.length + numericKey[j]];
        }
      }
      return encoded.map(c => c === undefined ? " " : c).join("");
}
  • 其四
function nico(k, m) {
      let ks = k.split('').sort()
      k = k.split('').map(l=>ks.indexOf(l))
      m = m.split('')
      let m2 = []
      for(let i = 0; m.length>0; i+=k.length) {
        m2.concat(new Array(k.length).fill(' '))
        k.forEach(p=> { m2[p+i] = m.shift()||' ' })
      }
      return m2.join('')
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,778评论 0 33
  • 直到所有事情都成了后来。 夜幕降临的时候,周围一切开始安静了,一天中最宁静的时刻已经来了。 我想我会一直记得有个人...
    天牙阅读 135评论 0 0
  • 今天无意中搜索,发现《徒然喜欢你》是部动漫。名字似乎很悲伤,但不得不说,这真是一部全程撒狗粮的动漫。 一部故事通常...
    张严心阅读 545评论 14 3
  • 憋了一天的文章终于在这个点完成了。 我的内心其实是——愧疚的,明明可以更早完成,却非拖到现在,这深深暴露了我人性中...
    李斯斯阅读 391评论 1 1
  • ——读武志红心理学课有感 直视那些晦暗的情绪和内在,每一次发生都是一次自我的提升。 今天看到一句话:我就是那个没什...
    B型血兔子007阅读 315评论 1 0