博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
查找最相近的字符串
阅读量:6540 次
发布时间:2019-06-24

本文共 3467 字,大约阅读时间需要 11 分钟。

这是一道codewars上面3级的题

原题:

Description:

I'm sure, you know Google's "Did you mean ...?", when you entered a search term and mistyped a word. In this kata we want to implement something similar.

You'll get an entered term (lowercase string) and an array of known words (also lowercase strings). Your task is to find out, which word from the dictionary is most similar to the entered one. The similarity is described by the minimum number of letters you have to add, remove or replace in order to get from the entered word to one of the dictionary. The lower the number of required changes, the higher the similarity between each two words.

Same words are obviously the most similar ones. A word that needs one letter to be changed is more similar to another word that needs 2 (or more) letters to be changed. E.g. the mistyped term berr is more similar to beer (1 letter to be replaced) than to barrel (3 letters to be changed in total).

Extend the dictionary in a way, that it is able to return you the most similar word from the list of known words.

Code Examples:

Dictionary fruits = new Dictionary(new String[]{"cherry", "pineapple", "melon", "strawberry", "raspberry"});fruits.findMostSimilar("strawbery"); // must return "strawberry"fruits.findMostSimilar("berry"); // must return "cherry"Dictionary things = new Dictionary(new String[]{"stars", "mars", "wars", "codec", "codewars"});things.findMostSimilar("coddwars"); // must return "codewars"Dictionary languages = new Dictionary(new String[]{"javascript", "java", "ruby", "php", "python", "coffeescript"});languages.findMostSimilar("heaven"); // must return "java"languages.findMostSimilar("javascript"); // must return "javascript" (same words are obviously the most similar ones)

 

I know, many of you would disagree that java is more similar to heaven than all the other ones, but in this kata it is ;)

Additional notes:

  • there is always exactly one possible solution

 

  这道题的大概意思就是,给你一个字符串数组ss,还有一个字符串s,从这个字符串数组ss中  找出通过最少次数的操作就能变成字符串s的那个字符串.

  什么是通过最少次数的操作?就是两个字符串,每添加或删除或替换一次单个字符,操作数加1,操作数最小的两个字符串就是最相似的字符串

  不明白的请看原题(其实英语没那么难,借助有道笔记看懂题的意思还是不太难的)

 

  这道题我没有想到什么好的解决方法,只好使用笨办法来解这道题

  (1)我把给出的数组中的每一个字符串依次和目标字符串进行比较,分别计算他们的操作数,然后取操作数最小的那个字符串。(总思路)

  (2)计算操作数的方法,假如有字符串a和字符串b:

      步骤1.依次取a的各个字符,然后依次新建3个字符串,分别是,添加一个b对应位置的字符,删除当前字符,替换当前字符为b对应位置的字符,

           然后把所有的生成的字符串都去和目标字符串比较一次,取出最相似的那个,然后这就算操作数加1

      步骤2.如果上一步生成出来的字符串和目标字符串相等,结束运行。否则,再拿上一步生成出来的最相似的那个字符串继续执行步骤一,直到结束

      记录每次循环的次数,最后得出总的操作数

  (3)如何算是最相似的字符串?

      依次比较两个字符串对应位置的的字符是否相等,相等则加1,不相等则减1,最后数越大相似程度越高

      比如'abc'和'abcd',相似值是3.  'bbc'和'abcd',相似值是2.  'abc'和'qabc',相似值是0,因为对应位置不相等

 

  我对我做这道题的方法非常不满意,但是我又没有想到更好的方法,这个方法效率极低,时间复杂度是大概是O(n^4).

  这绝对是我写过的时间复杂度最高的代码了,codewars上有很多人都比我的解题方式要好,

  但是由于没有说明,我看了看发现没怎么看懂。暂时没时间,等有时间了一定要重新做一遍这道题

  下面是代码,因为我当时是用的js来做这道题,所以是js代码。应该没太大影响吧,搞java的应该都会js

  

  

function Dictionary(words) {  this.words = words;} // 依次取数组中字符串和目标字符串比较,计算所需操作数,返回操作数最小的字符串Dictionary.prototype.findMostSimilar = function(term) {  var count = 99999;  var result = "";  for(var i = 0;i
countNum) { countNum = count; result = arr[i]; } } return result;} // 得到str1变成str2所需的总操作数Dictionary.prototype.getTotal = function(str1,str2) { if(str1 == str2) {    return 0; } var total = 0;    // 如果str1还没有变成str2,则继续下一次操作    // total记录进行过多少次操作 while(str1 != str2) { str1 = this.getNext(str1,str2); total++; } return total;}

 

 

转载于:https://www.cnblogs.com/wsss/p/5483171.html

你可能感兴趣的文章
Android标题栏,状态栏
查看>>
三数中值快速排序(长度小于3的数组转插入排序)
查看>>
Windows下安装Memcached for PHP
查看>>
hdu 1040 As Easy As A+B
查看>>
java笔记:SpringSecurity应用(二)
查看>>
vim命令
查看>>
php记录代码执行时间
查看>>
【C】strcpy()需谨慎使用;
查看>>
用Adobe Flash Professional CS6创建一个iOS应用程序
查看>>
简简单单几段代码让自己变成最合格的网站管理员
查看>>
Slim Text 0.0.9 发布, 代码开源!
查看>>
[置顶] 遵循Java EE标准体系的开源GIS服务平台之二:平台部署
查看>>
Session深度探索
查看>>
shell语法简单介绍
查看>>
wcf客户端终结点样本集合
查看>>
【Win 10 应用开发】RTM版的UAP项目解剖
查看>>
Java递归算法——阶乘
查看>>
ios开发应用内实现多语言自由切换
查看>>
转:iOS基于MVC的项目重构总结
查看>>
Tire树
查看>>