java - 我们如何用下划线替换重复的单词,Java‽

标签 java arrays string list text

我目前正在接受以下编程练习的培训:"Without repeats" 。该声明解释如下:

Given a String of words, return a String with all repeated words replaced with the appropriate numbers of underscores. For example, if the given String was: Here here here we go! Go w'e!?.

The expected output would be: Here __ __ we go! __ __

Notice how punctuation (commas, periods, etc.) and case are ignored for determining whether a word has been used, but they still show up in the final String.

我在伪代码中想到了以下内容:

Remove all special characters and get just alphabetic ones
Split words by space
For each word
  if word is not in result
    add the word into result
  else
    add underscores as needed
return result

在 Java 中我编写了以下代码:

import java.util.*;

public class RepeatDelete
{
   public static String withoutRepeats /*🚫🔁*/(String s)
   {
      //System.out.println("s: "+s); 
      List<String> uniques = new ArrayList<String>();
      List<String> result = new ArrayList<String>();
      String[] words = s.split(" ");
      //System.out.println("words: "+Arrays.toString(words)); 
      for(int i = 0, j = 0; i < words.length; i++){
        String word = words[i];
        String alphabetic = word.replaceAll("[^A-Za-z]","");
        //System.out.println("alphabetic: "+alphabetic); 
        for(; j < uniques.size(); j++){
          String unique = uniques.get(j);
          if(unique.toLowerCase().equals(alphabetic.toLowerCase())){
            result.add("_".repeat(word.length()));
            break;
          }
        }
        if(j == uniques.size()){
          result.add(word);
          uniques.add(alphabetic.toLowerCase());
        }
      }
      System.out.println("uniques: "+Arrays.toString(uniques.toArray()));
      return String.join(" ",result.toArray(new String[0]));
   }
}

以及测试用例(取自练习):

import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class ExampleTest
{
   @Test public void FixedTest1()
   {
      String lyrics="Here here here we go!\n"+
         "\n"+
         "So they're finally here, performing for you\n"+
         "If you know the words, you can join in too\n"+
         "Put your hands together, if you want to clap\n"+
         "As we take you through this monkey rap!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "DK\n"+
         "Donkey Kong!\n"+
         "\n"+
         "\n"+
         "He's the leader of the bunch, you know him well\n"+
         "He's finally back to kick some tail\n"+
         "His coconut gun can fire in spurts\n"+
         "If he shoots ya, it's gonna hurt!\n"+
         "He's bigger, faster, and stronger too\n"+
         "He's the first member of the DK crew!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "DK\n"+
         "Donkey Kong!\n"+
         "DK\n"+
         "Donkey Kong is here!\n"+
         "\n"+
         "\n"+
         "This Kong's got style, so listen up dudes\n"+
         "She can shrink in size, to suit her mood\n"+
         "She's quick and nimble when she needs to be\n"+
         "She can float through the air and climb up trees!\n"+
         "If you choose her, you'll not choose wrong\n"+
         "With a skip and a hop, she's one cool Kong!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "DK\n"+
         "Donkey Kong!\n"+
         "\n"+
         "\n"+
         "He has no style, he has no grace\n"+
         "Th-this Kong has a funny face\n"+
         "He can handstand when he needs to\n"+
         "And stretch his arms out, just for you\n"+
         "Inflate himself just like a balloon\n"+
         "This crazy Kong just digs this tune!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "DK\n"+
         "Donkey Kong!\n"+
         "DK\n"+
         "Donkey Kong is here!\n"+
         "\n"+
         "\n"+
         "He's back again and about time too\n"+
         "And this time he's in the mood\n"+
         "He can fly real high with his jetpack on\n"+
         "With his pistols out, he's one tough Kong!\n"+
         "He'll make you smile when he plays his tune\n"+
         "But Kremlings beware 'cause he's after you!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "DK\n"+
         "Donkey Kong!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "Finally, he's here for you\n"+
         "It's the last member of the DK crew!\n"+
         "This Kong's so strong, it isn't funny\n"+
         "Can make a Kremling cry out for mummy\n"+
         "Can pick up a boulder with relative ease\n"+
         "Makes crushing rocks seem such a breeze\n"+
         "He may move slow, he can't jump high\n"+
         "But this Kong's one hell of a guy!\n"+
         "\n"+
         "\n"+
         "C'mon Cranky, take it to the fridge!\n"+
         "\n"+
         "\n"+
         "Walnuts, peanuts, pineapple smells\n"+
         "Grapes, melons, oranges and coconut shells\n"+
         "Aww yeah!\n"+
         "Walnuts, peanuts, pineapple smells\n"+
         "Grapes, melons, oranges and coconut shells\n"+
         "Aww yeah!";
      String without="Here ____ ____ we go!\n"+
         "\n"+
         "So they're finally _____ performing for you\n"+
         "If ___ know the words, ___ can join in too\n"+
         "Put your hands together, __ ___ want to clap\n"+
         "As __ take ___ through this monkey rap!\n"+
         "Huh!\n"+
         "\n"+
         "\n"+
         "DK\n"+
         "Donkey Kong!\n"+
         "\n"+
         "\n"+
         "He's ___ leader of ___ bunch, ___ ____ him well\n"+
         "____ _______ back __ kick some tail\n"+
         "His coconut gun ___ fire __ spurts\n"+
         "__ he shoots ya, it's gonna hurt!\n"+
         "____ bigger, faster, and stronger ___\n"+
         "____ ___ first member __ ___ __ crew!\n"+
         "____\n"+
         "\n"+
         "\n"+
         "__\n"+
         "______ _____\n"+
         "__\n"+
         "______ ____ is _____\n"+
         "\n"+
         "\n"+
         "____ Kong's got style, __ listen up dudes\n"+
         "She ___ shrink __ size, __ suit her mood\n"+
         "She's quick ___ nimble when ___ needs __ be\n"+
         "___ ___ float _______ ___ air ___ climb __ trees!\n"+
         "__ ___ choose ____ you'll not ______ wrong\n"+
         "With a skip ___ _ hop, _____ one cool _____\n"+
         "____\n"+
         "\n"+
         "\n"+
         "__\n"+
         "______ _____\n"+
         "\n"+
         "\n"+
         "__ has no ______ __ ___ __ grace\n"+
         "Th-this ____ ___ _ funny face\n"+
         "__ ___ handstand ____ __ _____ __\n"+
         "___ stretch ___ arms out, just ___ ___\n"+
         "Inflate himself ____ like _ balloon\n"+
         "____ crazy ____ ____ digs ____ tune!\n"+
         "____\n"+
         "\n"+
         "\n"+
         "__\n"+
         "______ _____\n"+
         "__\n"+
         "______ ____ __ _____\n"+
         "\n"+
         "\n"+
         "____ ____ again ___ about time ___\n"+
         "___ ____ ____ ____ __ ___ ____\n"+
         "__ ___ fly real high ____ ___ jetpack on\n"+
         "____ ___ pistols ____ ____ ___ tough _____\n"+
         "He'll make ___ smile ____ __ plays ___ ____\n"+
         "But Kremlings beware 'cause ____ after ____\n"+
         "____\n"+
         "\n"+
         "\n"+
         "__\n"+
         "______ _____\n"+
         "____\n"+
         "\n"+
         "\n"+
         "________ ____ ____ ___ ___\n"+
         "____ ___ last ______ __ ___ __ _____\n"+
         "____ ______ __ strong, it isn't _____\n"+
         "___ ____ _ Kremling cry ___ ___ mummy\n"+
         "___ pick __ _ boulder ____ relative ease\n"+
         "Makes crushing rocks seem such _ breeze\n"+
         "__ may move slow, __ can't jump ____\n"+
         "___ ____ ______ ___ ____ __ _ guy!\n"+
         "\n"+
         "\n"+
         "C'mon Cranky, ____ __ __ ___ fridge!\n"+
         "\n"+
         "\n"+
         "Walnuts, peanuts, pineapple smells\n"+
         "Grapes, melons, oranges ___ _______ shells\n"+
         "Aww yeah!\n"+
         "________ ________ _________ ______\n"+
         "_______ _______ _______ ___ _______ ______\n"+
         "___ _____";
      assertEquals(without, RepeatDelete.withoutRepeats(lyrics));
   }

我们看到测试预期:

expected:<...
So they're finally [_____ performing for you
If ___ know the words, ___ can join in too
Put your hands together, __ ___ want to clap
As __ take ___ through this monkey rap!
Huh!


DK
Donkey Kong!


He's ___ leader of ___ bunch, ___ ____ him well
____ _______ back __ kick some tail
His coconut gun ___ fire __ spurts
__ he shoots ya, it's gonna hurt!
____ bigger, faster, and stronger ___
____ ___ first member __ ___ __ crew!
____


__
______ _____
__
______ ____ is _____


____ Kong's got style, __ listen up dudes
She ___ shrink __ size, __ suit her mood
She's quick ___ nimble when ___ needs __ be
___ ___ float _______ ___ air ___ climb __ trees!
__ ___ choose ____ you'll not ______ wrong
With a skip ___ _ hop, _____ one cool _____
____


__
______ _____


__ has no ______ __ ___ __ grace
Th-this ____ ___ _ funny face
__ ___ handstand ____ __ _____ __
___ stretch ___ arms out, just ___ ___
Inflate himself ____ like _ balloon
____ crazy ____ ____ digs ____ tune!
____


__
______ _____
__
______ ____ __ _____


____ ____ again ___ about time ___
___ ____ ____ ____ __ ___ ____
__ ___ fly real high ____ ___ jetpack on
____ ___ pistols ____ ____ ___ tough _____
He'll make ___ smile ____ __ plays ___ ____
But Kremlings beware 'cause ____ after ____
____


__
______ _____
____


________ ____ ____ ___ ___
____ ___ last ______ __ ___ __ _____
____ ______ __ strong, it isn't _____
___ ____ _ Kremling cry ___ ___ mummy
___ pick __ _ boulder ____ relative ease
Makes crushing rocks seem such _ breeze
__ may move slow, __ can't jump ____
___ ____ ______ ___ ____ __ _ guy!


C'mon Cranky, ____ __ __ ___ fridge!


Walnuts, peanuts, pineapple smells
Grapes, melons, oranges ___ _______ shells
Aww yeah!
________ ________ _________ ______
_______ _______ _______ ___ _______ ______
___ _____]>

但是,代码输出:

but was:<...
So they're finally [here, performing for you
If you know the words, you can join in too
Put your hands together, if you want to clap
As we take you through this monkey rap!
Huh!


DK
Donkey Kong!


He's the leader of the bunch, you know him well
He's finally back to kick some tail
His coconut gun can fire in spurts
If he shoots ya, it's gonna hurt!
He's bigger, faster, and stronger too
He's the first member of the DK crew!
Huh!


DK
Donkey Kong!
DK
Donkey Kong is here!


This Kong's got style, so listen up dudes
She can shrink in size, to suit her mood
She's quick and nimble when she needs to be
She can float through the air and climb up trees!
If you choose her, you'll not choose wrong
With a skip and a hop, she's one cool Kong!
Huh!


DK
Donkey Kong!


He has no style, he has no grace
Th-this Kong has a funny face
He can handstand when he needs to
And stretch his arms out, just for you
Inflate himself just like a balloon
This crazy Kong just digs this tune!
Huh!


DK
Donkey Kong!
DK
Donkey Kong is here!


He's back again and about time too
And this time he's in the mood
He can fly real high with his jetpack on
With his pistols out, he's one tough Kong!
He'll make you smile when he plays his tune
But Kremlings beware 'cause he's after you!
Huh!


DK
Donkey Kong!
Huh!


Finally, he's here for you
It's the last member of the DK crew!
This Kong's so strong, it isn't funny
Can make a Kremling cry out for mummy
Can pick up a boulder with relative ease
Makes crushing rocks seem such a breeze
He may move slow, he can't jump high
But this Kong's one hell of a guy!


C'mon Cranky, take it to the fridge!


Walnuts, peanuts, pineapple smells
Grapes, melons, oranges and coconut shells
Aww yeah!
Walnuts, peanuts, pineapple smells
Grapes, melons, oranges and coconut shells
Aww yeah!]>

我知道代码会在结果中插入重复的“此处”,但为什么呢?

正如您所注意到的,“here”已经添加到唯一值中,因此不应将其添加到结果中!

你能帮我一下吗?

我还读过:

您将如何调试这段代码,甚至提出一个更简单的方法?

如何用下划线替换重复的单词,Java‽

编辑:在尝试理解@kevin ternet答案并且不复制它之后,我编码了:

import java.util.*;

public class RepeatDelete
{
   public static String withoutRepeats(String s)
   {
      String[] words = s.split(" ");
      List<String> result = new ArrayList<String>(Arrays.asList(words));
      return String.join(" ",replaceRepeatedWords(result, 0));
   }
   public static List<String> replaceRepeatedWords(List<String> result, int i){
     String originalWord = result.get(i);
     Collections.replaceAll(result, result.get(i), "_".repeat(result.get(i).length()));
     result.set(i, originalWord);
     if(i == result.size() - 1){
       return result;
     }
     return replaceRepeatedWords(result, i+1);
   }
}

它不是用下划线替换所有重复的单词,而是替换最后一个。

给定:

“我们开始吧!\n”

它输出:

这里,我们开始吧!

而不是:

这里______我们出发!

最佳答案

如果不运行您的代码,我看不到任何明显的突出内容,但是我建议您以更简单的方式编写它,以便您更容易调试:

JDK 提供了一些类,可以让您的生活更轻松,例如,唯一单词列表最好实现为 Set<String> ,那么您不需要第二个嵌套循环,因为您可以简单地询问它 if (uniques.contains(alphabetic)) 。 (作为奖励,以这种方式测试它可以提供更好的性能,尽管性能现在不应该是您关心的问题)。您还可以使用 for-each 循环而不是使用数字索引:

for (String word : words.split(" ") {
    String alphabetic = word.replaceAll("...");
    // ...
}

大多数人都会同意,这对于人类来说“阅读”得更好,并且可读的代码更容易调试和使用。

我还建议使用StringBuilder构建您的输出字符串,而不是另一个列表。这几乎就是它设计的用例。

StringBuilder output = new StringBuilder();
output.append(word);
// etc...
System.out.println(output.toString());

祝你好运,我认为你有正确的方法,但是有更干净(更简单)的方法来实现它。请务必使用允许您设置断点并逐行单步执行正在运行的代码的 IDE。

关于java - 我们如何用下划线替换重复的单词,Java‽,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59309109/

相关文章:

c - 字符串赋值的指针。错误: expression is unassignable

java - 在 fragment 之间共享代码

java - 无法使用 File#renameTo() 方法重命名文件

java - 如何使用 shell 脚本从 .jar 文件复制文件夹

javascript - 当对象属性不存在时返回值

python - 在不使用 split() 的情况下拆分文本时出现问题

java - AndEngine加载图形: Where Do I put my assets folder and my resources?

Java - 如何在我的程序中为我的每个成绩显示一个字母等级,而不仅仅是我的最后一个?

javascript - 如何从 Ember.js 中另一个 ArrayController 的选定值更新一个 ArrayController 的内容

java - 在 Java 中将 JSON 转换为 List<List<String>>