LC 676 JS

/**
 * Initialize your data structure here.
 */
var MagicDictionary = function() {
    
};

/**
 * Build a dictionary through a list of words 
 * @param {string[]} dict
 * @return {void}
 */
MagicDictionary.prototype.buildDict = function(dict) {
    this.dict = dict;
};

/**
 * Returns if there is any word in the trie that equals to the given word after modifying exactly one character 
 * @param {string} word
 * @return {boolean}
 */
MagicDictionary.prototype.search = function(word) {
  for(let i = 0; i < this.dict.length; ++i){
      let obj = this.dict[i];
      TAG:
      if(obj.length === word.length){
          let diffCount = 0;
          for(let j = 0; j < obj.length; ++j){
              if(obj[j] !== word[j]){
                  diffCount++;
                  if(diffCount > 1){
                      j = obj.length;
                  }
              }
          }
          if(diffCount === 1){
              return true;
          }
      }
      else{
          continue;
      }
  }  
    return false;
};

/** 
 * Your MagicDictionary object will be instantiated and called as such:
 * var obj = Object.create(MagicDictionary).createNew()
 * obj.buildDict(dict)
 * var param_2 = obj.search(word)
 */
复制代码

转载于:https://juejin.im/post/5b701e8b518825610072aade

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值